Uniapp实现商城购买消息淡入淡出功能

2023-10-22 18:10

本文主要是介绍Uniapp实现商城购买消息淡入淡出功能,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

效果如下:

具体代码

先封装一个组件,名字FadeInOut.vue

<template><view><viewref="ani":animation="animationData"class="message":style="{ top: top + 'px', left: left + 'px' }"v-if="show"><view class="round bg-gradual-orange flex justify-start shadow" style="padding: 3px;"><view class="cu-avatar cu-a-sm round" :style="{ backgroundImage: `url(${info.img})` }"><!-- #ifdef APP-NVUE --><image :src="info.img" class="avatarimg"></image><!-- #endif --></view><view class="padding-lr-sm flex align-center"><text class="text-sm">{{ info.title }}</text></view></view></view></view>
</template><script>
// #ifdef APP-NVUE
const animation = uni.requireNativePlugin('animation');
// #endif
export default {name: 'Pengpai-FadeInOut',props: {//持续时间duration: {type: Number,default: 2600},//停留时间wait: {type: Number,default: 3000},//顶部距离pxtop: {type: Number,default: 350},//左边距离pxleft: {type: Number,default: 10},//动画半径radius: {type: Number,default: 30},//数据info: {type: [Array,Object],default: () => {return []}}},data() {return {animationData: {},animationNumber:{},show: true};},mounted(){this.donghua();},watch:{},methods: {donghua() {//进入// #ifndef APP-NVUEthis.animationData = uni.createAnimation({duration: this.duration / 2,timingFunction: 'ease'}).top(this.top - this.radius).opacity(0.9).step().export();// #endif// #ifdef APP-NVUEif (!this.$refs['ani']) return;animation.transition(this.$refs['ani'].ref,{styles: {transform: `translateY(-${this.radius/2}px)`,opacity: 1},duration: this.duration/2,timingFunction: 'linear',needLayout: false,delay: 0});// #endif//停留setTimeout(() => {//消失// #ifndef APP-NVUEthis.animationData = uni.createAnimation({duration: this.duration / 2,timingFunction: 'ease'}).top(this.top - this.radius * 2).opacity(0).step().export();// #endif// #ifdef APP-NVUEif (!this.$refs['ani']) return;animation.transition(this.$refs['ani'].ref,{styles: {transform: `translateY(-${this.radius}px)`,opacity: 0},duration: this.duration/2,timingFunction: 'linear',needLayout: false,delay: 0});// #endif}, this.wait);}}
};
</script><style scoped>
.message {position: fixed;z-index: 99999;opacity: 0;
}
.round {border-radius: 5000px;
}
.bg-gradual-orange {background-image: linear-gradient(45deg, #ff9700, #ed1c24);background-image: linear-gradient(to bottom right, #ff9700, #ed1c24);color: #ffffff;
}
.shadow {box-shadow: 4px 4px 5px rgba(217, 109, 26, 0.2);
}
.flex {display: flex;flex-direction: row;
}
.justify-start {justify-content: flex-start;
}
.cu-avatar {font-variant: small-caps;display: inline-flex;white-space: nowrap;background-size: cover;background-position: center;vertical-align: middle;margin: 0;padding: 0;text-align: center;justify-content: center;align-items: center;background-color: #ccc;color: #ffffff;position: relative;width: 30px;height: 30px;font-size: 1.5em;
}.avatarimg {width: 30px;height: 30px;border-radius: 50px;
}.cu-a-sm {width: 30px;height: 30px;font-size: 1em;
}
.padding-lr-sm {padding-left: 20upx;padding-right: 20upx;
}
.align-center {align-items: center;
}
.margin-left-xs {margin-left: 10upx;
}
.text-bold {font-weight: bold;
}
.margin-lr-sm {margin-left: 20upx;margin-right: 20upx;
}
.text-sm {font-size: 15px;color: #ffffff;
}
</style>

然后引入这个组件

<template><view><Pengpai-FadeInOut:duration="2000":wait="1000":top="150":left="10":radius="60":loop="true":info="item"v-for="(item, index) in list":key="index"></Pengpai-FadeInOut></view>
</template><script>import PengpaiFadeInOut from '../../components/Pengpai-FadeInOut/Pengpai-FadeInOut.vue'
export default {components:{PengpaiFadeInOut},data() {return {list: [],//演示数据demo_data: [{title: '踮起脚尖走向阳光 刚刚浏览本店',img: 'https://wx.qlogo.cn/mmopen/vi_32/DYAIOgq83er0aq5WuQhWxXcQoQbSnSPywUheQrot5biaFxV47nF2OB0aegkH12q2A6VkGUBDfUVqiaqgzVCJJicDg/132'},{title: '幸福的小女人  刚刚浏览本店',img: 'https://wx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTIOeUhleCNwcOoTtk9Y1zwmpw76FsmAr1bYcKia2AVPiapbtl34jac7SQgjMaibKDJCqjYaHwvmUh3IQ/132'},{title: '快乐天使  刚刚浏览本店',img: 'https://wx.qlogo.cn/mmopen/vi_32/OaXz0rjMsrHkZlfxeEqRhhUCKyaXyVSbCQZWFUeZQuUetKhbQRZiclqNQhFfv3yiclOzTl1FgZdjDpwAFG5gDhBg/132'},{title: '握不住的沙  刚刚浏览本店',img: 'https://wx.qlogo.cn/mmopen/vi_32/bVfMeCPxSQsfBRc1XFHiaAiaZvvdrXC9hMTWAHoqDZKk7HD2By7km1dc55eSEibibKwDaW3ZQ2Zcbccr4KzwILVquQ/132'},{title: '顺其自然  刚刚浏览本店',img: 'https://thirdwx.qlogo.cn/mmopen/vi_32/Q0j4TwGTfTJghoO6zuibOUG6AMubJJIUicbbWjyOyljFr4QVZecvRqEhHfkIribPfEyfxiaKY5MpiaAeVjvokLLATDw/132'}]};},methods: {add() {//随机获取演示数据let randomItem = this.demo_data[Math.floor(Math.random() * this.demo_data.length)];//追加一条数据this.list = this.list.concat(randomItem);}},onLoad() {setInterval(()=>{this.add()},3000)}
};
</script><style></style>

OK,完事

这篇关于Uniapp实现商城购买消息淡入淡出功能的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/262899

相关文章

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

C++11第三弹:lambda表达式 | 新的类功能 | 模板的可变参数

🌈个人主页: 南桥几晴秋 🌈C++专栏: 南桥谈C++ 🌈C语言专栏: C语言学习系列 🌈Linux学习专栏: 南桥谈Linux 🌈数据结构学习专栏: 数据结构杂谈 🌈数据库学习专栏: 南桥谈MySQL 🌈Qt学习专栏: 南桥谈Qt 🌈菜鸡代码练习: 练习随想记录 🌈git学习: 南桥谈Git 🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈🌈�

【C++】_list常用方法解析及模拟实现

相信自己的力量,只要对自己始终保持信心,尽自己最大努力去完成任何事,就算事情最终结果是失败了,努力了也不留遗憾。💓💓💓 目录   ✨说在前面 🍋知识点一:什么是list? •🌰1.list的定义 •🌰2.list的基本特性 •🌰3.常用接口介绍 🍋知识点二:list常用接口 •🌰1.默认成员函数 🔥构造函数(⭐) 🔥析构函数 •🌰2.list对象

【Prometheus】PromQL向量匹配实现不同标签的向量数据进行运算

✨✨ 欢迎大家来到景天科技苑✨✨ 🎈🎈 养成好习惯,先赞后看哦~🎈🎈 🏆 作者简介:景天科技苑 🏆《头衔》:大厂架构师,华为云开发者社区专家博主,阿里云开发者社区专家博主,CSDN全栈领域优质创作者,掘金优秀博主,51CTO博客专家等。 🏆《博客》:Python全栈,前后端开发,小程序开发,人工智能,js逆向,App逆向,网络系统安全,数据分析,Django,fastapi

让树莓派智能语音助手实现定时提醒功能

最初的时候是想直接在rasa 的chatbot上实现,因为rasa本身是带有remindschedule模块的。不过经过一番折腾后,忽然发现,chatbot上实现的定时,语音助手不一定会有响应。因为,我目前语音助手的代码设置了长时间无应答会结束对话,这样一来,chatbot定时提醒的触发就不会被语音助手获悉。那怎么让语音助手也具有定时提醒功能呢? 我最后选择的方法是用threading.Time

Android实现任意版本设置默认的锁屏壁纸和桌面壁纸(两张壁纸可不一致)

客户有些需求需要设置默认壁纸和锁屏壁纸  在默认情况下 这两个壁纸是相同的  如果需要默认的锁屏壁纸和桌面壁纸不一样 需要额外修改 Android13实现 替换默认桌面壁纸: 将图片文件替换frameworks/base/core/res/res/drawable-nodpi/default_wallpaper.*  (注意不能是bmp格式) 替换默认锁屏壁纸: 将图片资源放入vendo

C#实战|大乐透选号器[6]:实现实时显示已选择的红蓝球数量

哈喽,你好啊,我是雷工。 关于大乐透选号器在前面已经记录了5篇笔记,这是第6篇; 接下来实现实时显示当前选中红球数量,蓝球数量; 以下为练习笔记。 01 效果演示 当选择和取消选择红球或蓝球时,在对应的位置显示实时已选择的红球、蓝球的数量; 02 标签名称 分别设置Label标签名称为:lblRedCount、lblBlueCount

购买磨轮平衡机时应该注意什么问题和技巧

在购买磨轮平衡机时,您应该注意以下几个关键点: 平衡精度 平衡精度是衡量平衡机性能的核心指标,直接影响到不平衡量的检测与校准的准确性,从而决定磨轮的振动和噪声水平。高精度的平衡机能显著减少振动和噪声,提高磨削加工的精度。 转速范围 宽广的转速范围意味着平衡机能够处理更多种类的磨轮,适应不同的工作条件和规格要求。 振动监测能力 振动监测能力是评估平衡机性能的重要因素。通过传感器实时监

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略

Kubernetes PodSecurityPolicy:PSP能实现的5种主要安全策略 1. 特权模式限制2. 宿主机资源隔离3. 用户和组管理4. 权限提升控制5. SELinux配置 💖The Begin💖点点关注,收藏不迷路💖 Kubernetes的PodSecurityPolicy(PSP)是一个关键的安全特性,它在Pod创建之前实施安全策略,确保P

工厂ERP管理系统实现源码(JAVA)

工厂进销存管理系统是一个集采购管理、仓库管理、生产管理和销售管理于一体的综合解决方案。该系统旨在帮助企业优化流程、提高效率、降低成本,并实时掌握各环节的运营状况。 在采购管理方面,系统能够处理采购订单、供应商管理和采购入库等流程,确保采购过程的透明和高效。仓库管理方面,实现库存的精准管理,包括入库、出库、盘点等操作,确保库存数据的准确性和实时性。 生产管理模块则涵盖了生产计划制定、物料需求计划、