小程序?qū)崿F(xiàn)左右來(lái)回滾動(dòng)字幕效果
本文實(shí)例為大家分享了小程序左右來(lái)回滾動(dòng)字幕的具體代碼,供大家參考,具體內(nèi)容如下
wxml:
<!--pages/market/market.wxml--> <swiper indicator-dots="{{indicatorDots}}" autoplay="{{autoplay}}" interval="{{interval}}" duration="{{duration}}"> <block wx:for="{{imgUrls}}" wx:key="unique"> <swiper-item> <image src="{{item}}" class="slide-image"/> </swiper-item> </block> </swiper> <!--彈幕開(kāi)關(guān)--> <view class="barrage-Switch" style="color:{{barrageTextColor}};"> <switch id="switch_" bindchange="barrageSwitch"/> <text>彈幕</text> </view> <!--彈幕輸入框--> <view class="barrage-inputText" style="display:{{barrage_inputText}}"> <view class="barrage-input"> <input bindblur="bind_shoot" value="{{bind_shootValue}}"/> </view> <view class="barrage-shoot"> <button class="shoot" size="mini" bindtap="shoot">發(fā)射</button> </view> </view> <!--彈幕上單文字--> <view class="barrage-fly" style="display:{{barragefly_display}}"> <block wx:for="{{barrage_style}}" wx:key="unique"> <text class="barrage-textFly" style="color:{{item.barrage_shoottextColor}};left:{{item.barrage_phoneWidth}}px;top:{{item.barrageText_height}}px;">{{item.barrage_shootText}}</text> </block> </view>
wxss:
/* pages/market/market.wxss */ .slide-image{ width: 100%; } /* 彈幕選擇按鈕的操作*/ .barrage-Switch{ position: absolute; bottom: 10px; right: 10px; z-index: 2; } /* 彈幕輸入框的操作*/ .barrage-inputText{ position: absolute; display: flex; background-color: #BFBFBF; width: 100%; height: 40px; flex-direction: row; nav-index: 2; justify-content: center; align-items: center; bottom: 10%; } .barrage-input{ background-color: greenyellow; width: 60%; height: 30px; } .barrage-shoot{ margin-left: 10px; width: 25%; height: 30px; } .shoot{ width: 100%; color: black; } /*彈幕飛飛飛*/ .barrage-fly{ z-index: 3; height: 80%; width: 100%; position: absolute; top: 0; } .barrage-textFly{ position: absolute; }
market.js
// pages/market/market.js var barrage_style_arr = []; var barrage_style_obj = {}; var phoneWidth = 0; var timers = []; var timer; Page({ data: { imgUrls: [ 'http://img02.tooopen.com/images/20150928/tooopen_sy_143912755726.jpg', 'http://img06.tooopen.com/images/20160818/tooopen_sy_175866434296.jpg', 'http://img06.tooopen.com/images/20160818/tooopen_sy_175833047715.jpg' ], indicatorDots: true, autoplay: true, interval: 3000, duration: 500, barrageTextColor: "#D3D3D3", barrage_inputText: "none", barrage_shoottextColor: "black", bind_shootValue: "", barrage_style: [], barragefly_display: "none", }, // 生命周期函數(shù)--監(jiān)聽(tīng)頁(yè)面加載 onLoad: function (options) { var that = this; //獲取屏幕的寬度 wx.getSystemInfo({ success: function (res) { that.setData({ barrage_phoneWidth: res.windowWidth - 100, }) } }) phoneWidth = that.data.barrage_phoneWidth; console.log(phoneWidth); }, //是否打開(kāi)彈幕... barrageSwitch: function (e) { console.log(e); //先判斷沒(méi)有打開(kāi) if (!e.detail.value) { //清空彈幕 barrage_style_arr = []; //設(shè)置data的值 this.setData({ barrageTextColor: "#D3D3D3", barrage_inputText: "none", barragefly_display: "none", barrage_style: barrage_style_arr, }); //清除定時(shí)器 clearInterval(timer); } else { this.setData({ barrageTextColor: "#04BE02", barrage_inputText: "flex", barragefly_display: "block", }); //打開(kāi)定時(shí)器 timer = setInterval(this.barrageText_move, 800) } }, //發(fā)射按鈕 shoot: function (e) { //字體顏色隨機(jī) var textColor = "rgb(" + parseInt(Math.random() * 256) + "," + parseInt(Math.random() * 256) + "," + parseInt(Math.random() * 256) + ")"; // //設(shè)置彈幕字體的水平位置樣式 // var textWidth = -(this.data.bind_shootValue.length*0); //設(shè)置彈幕字體的垂直位置樣式 var barrageText_height = (Math.random()) * 266; barrage_style_obj = { // textWidth:textWidth, barrageText_height: barrageText_height, barrage_shootText: this.data.bind_shootValue, barrage_shoottextColor: textColor, barrage_phoneWidth: phoneWidth }; barrage_style_arr.push(barrage_style_obj); this.setData({ barrage_style: barrage_style_arr, //發(fā)送彈幕 bind_shootValue: "" //清空輸入框 }) //定時(shí)器 讓彈幕動(dòng)起來(lái) // this.timer= setInterval(this.barrageText_move,800); }, //定時(shí)器 讓彈幕動(dòng)起來(lái) barrageText_move: function () { var timerNum = barrage_style_arr.length; var textMove; for (var i = 0; i < timerNum; i++) { textMove = barrage_style_arr[i].barrage_phoneWidth; console.log("barrage_style_arr[" + i + "].barrage_phoneWidth----------:" + barrage_style_arr[i].barrage_phoneWidth); textMove = textMove - 20; barrage_style_arr[i].barrage_phoneWidth = textMove; //走完的移除掉 if (textMove <= -100) { // clearTimeout(this.timer); barrage_style_arr.splice(0, 1); i--; //全部彈幕運(yùn)行完 if (barrage_style_arr.length == 0) { this.setData({ barrage_style: barrage_style_arr, }) // clearInterval(this.timer); return; } } console.log("第" + i + "個(gè)定時(shí)器:", textMove); this.setData({ barrage_style: barrage_style_arr, }) } }, //綁定發(fā)射輸入框,將值傳遞給data里的bind_shootValue,發(fā)射的時(shí)候調(diào)用 bind_shoot: function (e) { this.setData({ bind_shootValue: e.detail.value }) }, })
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
JavaScript 獲取元素在父節(jié)點(diǎn)中的下標(biāo)(推薦)
jQuery中直接通過(guò)$(this).index()即可得到當(dāng)前元素的下標(biāo)。下面通過(guò)實(shí)例給大家介紹JavaScript 獲取元素在父節(jié)點(diǎn)中的下標(biāo),需要的朋友參考下吧2017-06-06微信小程序?qū)崿F(xiàn)導(dǎo)航欄和內(nèi)容上下聯(lián)動(dòng)功能代碼
這篇文章主要介紹了微信小程序?qū)崿F(xiàn)導(dǎo)航欄和內(nèi)容上下聯(lián)動(dòng)功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-06-06HTML+CSS+JS實(shí)現(xiàn)完美兼容各大瀏覽器的TABLE固定列
本文給大家分享的是使用HTML+CSS+JS實(shí)現(xiàn)完美兼容各大瀏覽器的TABLE固定列的方法和示例,非常的實(shí)用,特別是在BS架構(gòu)的企業(yè)級(jí)應(yīng)用,有需要的小伙伴可以參考下。2015-04-04js實(shí)現(xiàn)年月日表單三級(jí)聯(lián)動(dòng)
這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)年月日表單三級(jí)聯(lián)動(dòng),生日欄表單三級(jí)聯(lián)動(dòng),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-03-03bootstrap datepicker 與bootstrapValidator同時(shí)使用時(shí)選擇日期后無(wú)法正常觸發(fā)校驗(yàn)的解
這篇文章主要介紹了bootstrap datepicker 與bootstrapValidator同時(shí)使用時(shí)選擇日期后無(wú)法正常觸發(fā)校驗(yàn)的解決思路的相關(guān)資料,需要的朋友可以參考下2016-09-09JS實(shí)現(xiàn)選項(xiàng)卡實(shí)例詳解
這篇文章主要介紹了JS實(shí)現(xiàn)選項(xiàng)卡的方法,結(jié)合實(shí)例形式詳細(xì)講述了JavaScript實(shí)現(xiàn)選項(xiàng)卡的布局與功能實(shí)現(xiàn)的完整步驟及相關(guān)技巧,需要的朋友可以參考下2015-11-11javascript實(shí)現(xiàn)類似超鏈接的效果
這篇文章主要介紹了使用javascript實(shí)現(xiàn)類似超鏈接的效果的特效,通過(guò)示例熟悉javascript事件,這里推薦給大家。2014-12-12javascript獲取不重復(fù)的隨機(jī)數(shù)的方法比較
js永不重復(fù)隨機(jī)數(shù)實(shí)現(xiàn)代碼比較2008-09-09