中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

微信小程序中組件marquee有什么用

發布時間:2021-07-05 11:26:02 來源:億速云 閱讀:168 作者:小新 欄目:web開發

小編給大家分享一下微信小程序中組件marquee有什么用,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

微信小程序組件 marquee實例詳解

1. marquee標簽

html是有marquee標簽的,可以實現跑馬燈效果,但小程序沒有,所以要實現。這里考慮使用css3的animation實現。

html的marquee是這樣使用的。

<marquee direction="left" behavior="scroll" scrollamount="1" scrolldelay="0" loop="-1" width="200" height="50" bgcolor="#0099FF" hspace="10" vspace="10">
   hello world
</marquee>

2. wxml

<view class="marquee_container" >
  <view class="marquee_text">{{marquee.text}}</view>
</view>

傳入wxml的是個json對象

marquee:{
  width:12,
  text:'hello world'
}

而那個奇怪的--marqueeWidth是給@keyframes傳的變量。內聯設置變量,css文件中也可以獲取到該變量。

3. wxss

@keyframes around {
  from {
   margin-left: 100%;
  }
  to {
   margin-left: var(--marqueeWidth--);// var接受傳入的變量
  }
 }

.marquee_container{
 background-color: #0099FF;
 height: 1.2em;
 position: relative;
 width: 100%;
}
.marquee_container:hover{
 animation-play-state: paused; // 不起作用
}
.marquee_text{
 display: inline-block;
 white-space: nowrap;
 animation-name: around;
 animation-duration: 5s;
 animation-iteration-count: infinite;
 animation-timing-function:linear;
}

4. js

export default {
 getWidth:(str)=>{
  return [].reduce.call(str, (pre, cur, index, arr) => {
   if (str.charCodeAt(index) > 255) {// charCode大于255是漢字
    pre++;
   } else {
    pre += 0.5;
   }
   return pre;
  }, 0);
 },
 getDuration:(str)=>{// 保留,根據文字長度設置時間
  return this.getWidth()/10;
 }
}

以上是組件的封裝。

5. 使用

// wxml
<include src="../component/marquee/marquee.wxml" />
// wxss
@import "../component/marquee/marquee.wxss";
// js
import marquee from '../component/marquee/marquee.js';

var options = Object.assign(marquee, {
 data: {
  motto: 'Hello World',
  userInfo: {},
  marquee: { text: '你好,中國!hello,world!' }
 },
 onLoad: function () {
  // ...

  const str = this.data.marquee.text;
  const width = this.getWidth(str);
  console.log('width',width);
  this.setData({ [`${'marquee'}.width`]: width });
 }
});
Page(options);

看完了這篇文章,相信你對“微信小程序中組件marquee有什么用”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

郴州市| 永丰县| 彭山县| 大港区| 内丘县| 宁夏| 黎城县| 石台县| 黔西| 吴江市| 南漳县| 阿克陶县| 湖州市| 惠东县| 开鲁县| 凤台县| 郧西县| 红原县| 扶绥县| 通海县| 博罗县| 博白县| 上高县| 西贡区| 阆中市| 寿宁县| 西丰县| 天祝| 栾川县| 安平县| 饶阳县| 白城市| 赣榆县| 铁岭县| 花垣县| 成武县| 囊谦县| 樟树市| 隆子县| 潞西市| 五指山市|