微信小程序弹幕墙(祝福墙)

博客介绍利用四个数组和CSS3动画animation解决左右弹幕重叠问题。该应用为祝福墙,用户发送弹幕到后台审核,审核通过后在前端显示,还涉及请求后的数据操作(res.data)。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

利用四个数组和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.cnt}}" style="width:{{danmuFake0.max}}rpx; animation: dmAnimation {{danmuFake0.max / 150}}s linear 1s infinite backwards;">
							<view wx:for="{{danmuFake0.cnt}}" wx:key="danmuFake0cntindex" 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.cnt}}" style="width:{{danmuFake1.max}}rpx; animation: dmAnimation {{danmuFake1.max / 150}}s linear 3s infinite backwards;">
							<view wx:for="{{danmuFake1.cnt}}" wx:key="danmuFake1cnt" 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.cnt}}"  style="width:{{danmuFake2.max}}rpx; animation: dmAnimation {{danmuFake2.max / 150}}s linear 5s infinite backwards;">
							<view wx:for="{{danmuFake2.cnt}}" wx:key="danmuFake2cnt" 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.cnt}}" style="width:{{danmuFake3.max}}rpx; animation: dmAnimation {{danmuFake3.max / 150}}s linear 7s infinite backwards;">
							<view wx:for="{{danmuFake3.cnt}}" wx:key="danmuFake3cnt" 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>

请求后的数据操作(res.data)

  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
    })
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值