国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

node.js|vue.js|jquery|angularjs|React|json|js教程|

服務(wù)器之家 - 編程語言 - JavaScript - js教程 - 微信小程序?qū)崿F(xiàn)走馬燈效果實(shí)例

微信小程序?qū)崿F(xiàn)走馬燈效果實(shí)例

2022-02-19 17:27程序猿tx js教程

這篇文章主要給大家介紹了關(guān)于微信小程序?qū)崿F(xiàn)走馬燈效果的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

日常開發(fā)中,我們經(jīng)常會遇到文字橫向循環(huán)滾動的效果,俗稱走馬燈,也是項(xiàng)目中經(jīng)常會使用的一個功能。在網(wǎng)頁web前端很常見,今天就介紹下小程序的實(shí)現(xiàn)方式,一種是用的css樣式實(shí)現(xiàn),另一種是運(yùn)用小程序的動畫功能實(shí)現(xiàn)。

微信小程序?qū)崿F(xiàn)走馬燈效果實(shí)例

@keyframes 實(shí)現(xiàn)

利用@keyframes的規(guī)則來實(shí)現(xiàn),非常方便,只需要css樣式就可以滿足,使用方法跟web上一樣。

?
1
2
3
<view class="marquee">
 <text>這是一段滾動的文字</text>
</view>

樣式類,from to 來定義動畫的開始結(jié)束,這里是從屏幕最右端向左滑,觸及到最左側(cè)后重新開始新一輪動畫。

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
@keyframes translation {
 from {
 margin-left: 750rpx; //從屏幕最右端開始
 }
 
 to {
 margin-left: 0px;
 }
}
 
.marquee{
 white-space: nowrap;
 animation-name: translation; //定義動畫的名稱
 animation-duration: 3s;
 animation-iteration-count: infinite;
 animation-timing-function: linear;
}

如果想要的效果是滑動到左側(cè)之后,文字繼續(xù)左滑,直到全部消失,再從最右開始動畫的,那么就需要再加上文字的長度,這里需要去計(jì)算文字的長度,使用SelectorQuery 對象實(shí)例來拿到文字節(jié)點(diǎn)的寬度。在頁面首次渲染完畢onReady時執(zhí)行,查詢到對應(yīng)文字節(jié)點(diǎn)信息的對象,得到文字的長度。這里定義的是上面的marquee類名。

?
1
2
3
4
5
6
7
8
9
10
11
onReady: function () {
 let query = wx.createSelectorQuery();
 query.select('.marquee').boundingClientRect();
 query.exec((res) => {
  if (res[0]) {
  this.setData({
   marqueeWidth: res[0].width
  })
  }
 })
}

然后使用css var() 函數(shù)插入定義的屬性值,到結(jié)束的位置處,讓它走完整個屏幕以及自身文字的長度。定義一個名為 "--marqueeWidth" 的屬性,然后在wxss樣式文件里使用var()函數(shù)調(diào)用該屬性:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
<view class="marquee" style="--marqueeWidth:-{{marqueeWidth}}px">
 <text>這是一段滾動的文字</text>
</view>
 
wxss樣式里:
@keyframes translation {
 from {
 margin-left: 750rpx;
 }
 
 to {
 margin-left: var(--marqueeWidth);
 }
}

這是通過css的方式實(shí)現(xiàn)的,非常方便,但是會出現(xiàn)在部分機(jī)型上適配的問題,還有一種是通過Animation動畫實(shí)現(xiàn)。

animation實(shí)現(xiàn)

通過animation動畫實(shí)例來完成動畫,一開始讓視圖位于屏幕右側(cè)超出屏幕的。

?
1
2
3
4
5
6
7
8
9
<view class="marquee2" bindtransitionend="animationend" animation="{{animationData}}">
    <text>這是一段滾動的文字</text>
</view>
 
.marquee2{
 display: inline-block;
 white-space: nowrap;
 margin-left: 750rpx;
}

同樣這里計(jì)算了文字的長度,通過Animation.translate(number tx, number ty)平移屬性進(jìn)行移動操作,直至移出整個屏幕。在一組動畫完成之后,調(diào)用bindtransitionend回調(diào),再一次去執(zhí)行動畫,

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
this.animation = wx.createAnimation({
 duration: 3000,
 timingFunction: 'linear'
});
var query = wx.createSelectorQuery();
query.select('.marquee2').boundingClientRect();
query.exec((res) => {
 if (res[0]) {
 this.setData({
  marqueeWidth: res[0].width //文字長度
 }, () => {
  this.doAnim()
 })
 }
})
 
 
doAnim: function () {
 //向左滾動到超出屏幕,這里臨時寫死的屏幕寬度375px
 this.animation.translate(-this.data.marqueeWidth - 375, 0).step();
 setTimeout(() => {
  this.setData({
  animationData: this.animation.export(),
  });
 }, 10)
}

在第一次動畫結(jié)束之后,重新開始,通過animationend監(jiān)聽動畫結(jié)束,然后再次執(zhí)行。

?
1
2
3
4
5
6
7
8
9
10
animationend() {
 //復(fù)位
 this.animation.translate(0, 0).step({ duration: 0 });
 this.setData({
  animationData: this.animation.export()
 }, () => {
  //重新開始動畫
  this.doAnim()
 });
}

這個動畫在小程序開發(fā)工具上運(yùn)行會有動畫突然暫停的現(xiàn)象,可以用手機(jī)試下的。

相對而言是比較容易實(shí)現(xiàn)的,而且走馬燈的效果也是我們在項(xiàng)目中經(jīng)常會用到的,正好也可以熟悉下小程序的動畫的。

總結(jié)

到此這篇關(guān)于微信小程序?qū)崿F(xiàn)走馬燈效果實(shí)例的文章就介紹到這了,更多相關(guān)小程序走馬燈效果內(nèi)容請搜索服務(wù)器之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持服務(wù)器之家!

原文鏈接:https://juejin.cn/post/6916884147348701192

延伸 · 閱讀

精彩推薦
  • js教程在JavaScript中查找字符串中最長單詞的三種方法(推薦)

    在JavaScript中查找字符串中最長單詞的三種方法(推薦)

    這篇文章主要介紹了在JavaScript中查找字符串中最長單詞的三種方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋...

    Hunter網(wǎng)絡(luò)安全7352022-01-04
  • js教程微信小程序onShareTimeline()實(shí)現(xiàn)分享朋友圈

    微信小程序onShareTimeline()實(shí)現(xiàn)分享朋友圈

    這篇文章主要給大家介紹了關(guān)于微信小程序onShareTimeline()實(shí)現(xiàn)分享朋友圈的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定...

    遠(yuǎn)航_6232021-12-27
  • js教程詳解 TypeScript 函數(shù)聲明和重載

    詳解 TypeScript 函數(shù)聲明和重載

    在 JavaScript 中,函數(shù)是構(gòu)建應(yīng)用的一塊基石,我們可以使用函數(shù)抽離可復(fù)用的邏輯、抽象模型、封裝過程。在TypeScript中,函數(shù)仍然是最基本、最重要的概念...

    前端充電寶7142022-01-05
  • js教程js刪除對象中的某一個字段的方法實(shí)現(xiàn)

    js刪除對象中的某一個字段的方法實(shí)現(xiàn)

    這篇文章主要介紹了js刪除對象中的某一個字段的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的...

    兔子零847392021-12-29
  • js教程ES5和ES6中類的區(qū)別總結(jié)

    ES5和ES6中類的區(qū)別總結(jié)

    這篇文章主要給大家介紹了ES5和ES6中類的區(qū)別的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋...

    Totora612292021-12-16
  • js教程js正則表達(dá)式簡單校驗(yàn)方法

    js正則表達(dá)式簡單校驗(yàn)方法

    在本篇文章里小編給大家整理了一篇關(guān)于js正則表達(dá)式簡單校驗(yàn)方法,有需要的朋友們可以參考下。...

    小妮淺淺11292021-12-24
  • js教程js制作提示框插件

    js制作提示框插件

    這篇文章主要介紹了js制作提示框插件的方法,幫助大家更好的理解和使用js,感興趣的朋友可以了解下...

    lanshanxiao10242021-12-18
  • js教程js實(shí)現(xiàn)驗(yàn)證碼干擾(靜態(tài))

    js實(shí)現(xiàn)驗(yàn)證碼干擾(靜態(tài))

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)驗(yàn)證碼干擾,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下...

    lzh~5242022-01-22
主站蜘蛛池模板: 欧美精品一二区 | 一级黄免费看 | 精品国内 | 国产一区二区影院 | 亚洲视频在线播放 | 成人午夜影院 | 免费黄色电影在线观看 | 国内自拍视频在线观看 | 在线第一页 | 国产成人精品久久二区二区91 | www.天天操.com| 色xx综合网 | 国产精品爱久久久久久久 | 成人在线免费看视频 | 国产精品一区久久久 | 精品久久久久久久久久久久久久 | 国产一区成人 | 国产美女视频自拍 | 日韩在线观看 | 亚洲一区在线观看视频 | 福利成人 | 男女免费观看在线爽爽爽视频 | 欧美一级在线观看 | a级毛片免费高清视频 | www.久草.com| 一级片免费在线 | 在线国产视频 | 国产精品成人一区二区三区夜夜夜 | 2018啪一啪 | 欧美中文字幕一区二区三区 | 久久视频一区 | 黄色国产 | 亚洲午夜视频在线 | 欧美日韩在线电影 | 国产依人| 毛片免费观看 | 黄色毛片视频网站 | 久久久999精品视频 午夜精品久久久久久久久久久久 | 成人福利在线观看 | 午夜精品福利在线观看 | 亚洲一区二区三区在线播放 |