祝福墙html,微信小程序实现弹幕墙(祝福墙)

本文实例为大家分享了微信小程序实现弹幕墙的具体代码,供大家参考,具体内容如下

为了解决左右弹幕重叠问题,也是找了网上挺多案例,最后都不行,最后利用四个数组和css3动画animation来解决

这是个祝福墙,用户发送弹幕到后台审核,审核通过显示在前端

d90ce85c2e8ad453036a23690f6c9e6e.png

{{item.title}}

{{item.title}}

{{item.title}}

{{item.title}}

发送

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.length*24,

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.length*24,

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.length*24,

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.length*24,

left: left,

idx: num

});

}

}

that.setData({

danmuFake0: {

max : danmu0[danmu0.length-1].left + danmu0[danmu0.length-1].width + 80,

cnt:danmu0

},

danmuFake1: {

max : danmu1[danmu1.length-1].left + danmu1[danmu1.length-1].width + 80,

cnt:danmu1

},

danmuFake2: {

max : danmu2[danmu2.length-1].left + danmu2[danmu2.length-1].width + 80,

cnt:danmu2

},

danmuFake3: {

max : danmu3[danmu3.length-1].left + danmu3[danmu3.length-1].width + 80,

cnt: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

})

为大家推荐现在关注度比较高的微信小程序教程一篇:小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持站圈网。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值