微信小程序实现弹幕墙(祝福墙)
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要为大家详细介绍了微信小程序实现弹幕墙、祝福墙效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
本文实例为大家分享了微信小程序实现弹幕墙的具体代码,供大家参考,具体内容如下
为了解决左右弹幕重叠问题,也是找了网上挺多案例,都不行,利用四个数组和css3动画animation来解决
这是个祝福墙,用户发送弹幕到后台审核,审核通过显示在前端
<!-- 弹幕墙 --> <view class="barrage" wx:if="{{IsPush}}"> <view class="barrage-a"> <view class="barrage-b"><image src="../../images/img/a-13.png"></image></view> <view class="barrage-c"> <view class="video_container"> <view class='danmu'> <view class="danmu_wrapper"> <view class="li0" wx:if="{{danmuFake0.t}}" style="width:{{danmuFake0.max}}rpx; animation: dmAnimation {{danmuFake0.max / 150}}s linear 1s infinite backwards;"> <view wx:for="{{danmuFake0.t}}" wx:key="danmuFake0tindex" data-idx="{{item.idx}}" data-width="{{item.width}}" class='danmu-li rowAndColCenter' style="left:{{item.left}}rpx"> <text>{{item.title}}</text> </view> </view> <view class="li1" wx:if="{{danmuFake1.t}}" style="width:{{danmuFake1.max}}rpx; animation: dmAnimation {{danmuFake1.max / 150}}s linear 3s infinite backwards;"> <view wx:for="{{danmuFake1.t}}" wx:key="danmuFake1t" data-idx="{{item.idx}}" data-width="{{item.width}}" class='danmu-li rowAndColCenter' style="left:{{item.left}}rpx"> <text>{{item.title}}</text> </view> </view> <view class="li2" wx:if="{{danmuFake2.t}}" style="width:{{danmuFake2.max}}rpx; animation: dmAnimation {{danmuFake2.max / 150}}s linear 5s infinite backwards;"> <view wx:for="{{danmuFake2.t}}" wx:key="danmuFake2t" data-idx="{{item.idx}}" data-width="{{item.width}}" class='danmu-li rowAndColCenter' style="left:{{item.left}}rpx"> <text>{{item.title}}</text> </view> </view> <view class="li3" wx:if="{{danmuFake3.t}}" style="width:{{danmuFake3.max}}rpx; animation: dmAnimation {{danmuFake3.max / 150}}s linear 7s infinite backwards;"> <view wx:for="{{danmuFake3.t}}" wx:key="danmuFake3t" data-idx="{{item.idx}}" data-width="{{item.width}}" class='danmu-li rowAndColCenter' style="left:{{item.left}}rpx"> <text>{{item.title}}</text> </view> </view> </view> </view> </view> <form> <view class="danmuGrop"> <input type="text" name="Name" bindinput="getInput" class="danmuinput" placeholder='请输入你的祝福语' placeholder-style="color:#b6b2a6;opacity:.55;"></input> <button style="width:108rpx;" class="sendDanmu" bindtap='sendDanmu' form-type='reset'> <image src="/images/img/a-3.png"></image> <text>发送</text> </button> </view> </form> </view> </view> </view>
js:
var danmu0=[]; var danmu1=[]; var danmu2=[]; var danmu3=[]; for (var i = 0; i < res.data.Entity.length; i++) { const num = Math.floor(Math.random() 4); if(num == 0){ var left = 0; if(danmu0.length){left = danmu0[danmu0.length-1].left + danmu0[danmu0.length-1].width + 80;} left = left < 0 ? 0 : left; danmu0.push({ title: res.data.Entity[i].NewsContent, left: left, width:res.data.Entity[i].NewsContent.length24, idx: num }); } if(num == 1){ var left = 0; if(danmu1.length){left = danmu1[danmu1.length-1].left + danmu1[danmu1.length-1].width + 80;} left = left < 0 ? 0 : left; danmu1.push({ title: res.data.Entity[i].NewsContent, width:res.data.Entity[i].NewsContent.length24, left: left, idx: num }); } if(num == 2){ var left = 0; if(danmu2.length){left = danmu2[danmu2.length-1].left + danmu2[danmu2.length-1].width + 80;} left = left < 0 ? 0 : left; danmu2.push({ title: res.data.Entity[i].NewsContent, width:res.data.Entity[i].NewsContent.length24, left: left, idx: num }); } if(num == 3){ var left = 0; if(danmu3.length){left = danmu3[danmu3.length-1].left + danmu3[danmu3.length-1].width + 80;} left = left < 0 ? 0 : left; danmu3.push({ title: res.data.Entity[i].NewsContent, width:res.data.Entity[i].NewsContent.length24, left: left, idx: num }); } } that.setData({ danmuFake0: { max : danmu0[danmu0.length-1].left + danmu0[danmu0.length-1].width + 80, t:danmu0 }, danmuFake1: { max : danmu1[danmu1.length-1].left + danmu1[danmu1.length-1].width + 80, t:danmu1 }, danmuFake2: { max : danmu2[danmu2.length-1].left + danmu2[danmu2.length-1].width + 80, t:danmu2 }, danmuFake3: { max : danmu3[danmu3.length-1].left + danmu3[danmu3.length-1].width + 80, t:danmu3 } }) var danmuMaxWid = Math.max(that.data.danmuFake0.max,that.data.danmuFake1.max,that.data.danmuFake2.max,that.data.danmuFake3.max); that.setData({ danmuMaxWid:danmuMaxWid })
为大家推荐现在关注度比较高的微信小程序教程一篇长沙网络推广为大家精心整理的,希望喜欢。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:微信小程序实现底部弹出框
下一篇:一篇超完整的Vue新手入门指导教程
编程语言
- 宿迁百度关键词排名指南:实现精准营销的关键
- 四川SEO优化怎么做网络推广
- 立昂技术备案老域名收购:如何为您的业务赋能
- 安徽百度关键词seo贵不贵,一般需要多少钱
- 吉林百度快照排名怎么做电话营销
- 多伦新手做SEO怎么做
- 甘肃优化关键词排名推广怎么做论坛营销
- 沙雅SEO网站推广:提升您的在线可见性
- 四川SEO优化如何提升销售额和销售量
- 聂荣网站排名优化:提升网站可见性的全方位指
- 涞水SEO:提升地方企业在线可见性的策略
- 辽宁百度seo排名怎样做网站排名
- 临湘哪有关键词排名优化:提升网站可见度的关
- 黑龙江百度网站优化有没有优惠
- 凉城优化关键词排名推广:提升您的网络可见性
- 萝北整站优化:提升您网站流量和排名的全面指