微信小程序?qū)崿F(xiàn)彈幕墻(祝福墻)
本文實(shí)例為大家分享了微信小程序?qū)崿F(xiàn)彈幕墻的具體代碼,供大家參考,具體內(nèi)容如下
為了解決左右彈幕重疊問題,也是找了網(wǎng)上挺多案例,最后都不行,最后利用四個(gè)數(shù)組和css3動(dòng)畫animation來(lái)解決
這是個(gè)祝福墻,用戶發(fā)送彈幕到后臺(tái)審核,審核通過顯示在前端
<!-- 彈幕墻 --> <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='請(qǐng)輸入你的祝福語(yǔ)' 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>發(fā)送</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.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 })
為大家推薦現(xiàn)在關(guān)注度比較高的微信小程序教程一篇:《微信小程序開發(fā)教程》小編為大家精心整理的,希望喜歡。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript寫的一個(gè)DIV 彈出網(wǎng)頁(yè)對(duì)話框
自己整理得一個(gè)JavaScript寫的一個(gè)DIV 彈出網(wǎng)頁(yè)對(duì)話框2009-08-08詳解JavaScript的閉包、IIFE、apply、函數(shù)與對(duì)象
本文主要對(duì)JavaScript的閉包、IIFE、apply、函數(shù)與對(duì)象進(jìn)行詳細(xì)介紹。有很好的參考價(jià)值,需要的朋友一起來(lái)看下吧2016-12-12javascript圖片切換綜合實(shí)例(循環(huán)切換、順序切換)
這篇文章主要介紹了javascript圖片切換綜合實(shí)例,包括javascript圖片循環(huán)切換、javascript圖片順序切換,兩張圖片的切換,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-01-01基于BootStrap multiselect.js實(shí)現(xiàn)的下拉框聯(lián)動(dòng)效果
當(dāng)option特別多時(shí),一般的下拉框選擇起來(lái)就有點(diǎn)力不從心了,所以使用multiselect是個(gè)很好的選擇。在網(wǎng)上找了半天找到了解決方案,具體實(shí)現(xiàn)代碼大家參考下本文吧2017-07-07javascript 就地編輯實(shí)現(xiàn)代碼
最近正在看《javascript設(shè)計(jì)模式》,其中有一個(gè)'就地編輯'的示例,用來(lái)表現(xiàn)不同的繼承方式,看完之后想自己憑理解寫一個(gè)類似的東西。2010-05-05JavaScript HTML DOM 元素 (節(jié)點(diǎn))新增,編輯,刪除操作實(shí)例分析
這篇文章主要介紹了JavaScript HTML DOM 元素 (節(jié)點(diǎn))新增,編輯,刪除操作,結(jié)合實(shí)例形式分析了JavaScript針對(duì)HTML DOM 元素 (節(jié)點(diǎn))的新增,編輯,刪除相關(guān)操作技巧與使用注意事項(xiàng),需要的朋友可以參考下2020-03-03用js腳本控制asp.net下treeview的NodeCheck的實(shí)現(xiàn)代碼
根據(jù)TreeView2.js修改后的TreeView父節(jié)點(diǎn)與子節(jié)點(diǎn)的CheckBox聯(lián)動(dòng).2010-03-03JavaScript與Image加載事件(onload)、加載狀態(tài)(complete)
以前寫過一個(gè)圖片等比縮放的Js函數(shù),缺陷是要等到所有圖片都加載完畢了,才能進(jìn)行等比縮放。2011-02-02利用JS hash制作單頁(yè)Web應(yīng)用的方法詳解
這篇文章主要給大家介紹了關(guān)于如何利用JS hash制作單頁(yè)Web應(yīng)用的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-10-10