欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解vue 自定義marquee無縫滾動組件

 更新時(shí)間:2019年04月09日 11:38:10   作者:站住,別跑  
這篇文章主要介紹了vue自定義marquee無縫滾動組件,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

先上效果圖:

(1) 看起來可能有點(diǎn)卡頓,但是實(shí)際上頁面上看起來挺順暢的。

(2) 思路就是獲取每一個(gè)列表的寬度,設(shè)置定時(shí)器移動列表,當(dāng)移動的距離達(dá)到一個(gè)列表的寬度的時(shí)候,把這個(gè)距離放到數(shù)組的最后。這樣就能達(dá)成無縫循環(huán)滾動了。

 大致的情況就是下面這樣:

 

接下來就是代碼的實(shí)現(xiàn):

index.vue 引入組件

<template>
 <div>
  <marqueeLeft :send-val='send'></marqueeLeft >
 </div>
</template>
<script>
 import marqueeLeft from '../components/marquee'
 export default {
  data:function(){
   return{
    send:[{place: "來自東莞市的", name: "黃女士"},
   {place: "來自太原市的", name: "吳先生"},
   {place: "來自常州市的", name: "戚先生"},
   {place: "來自金華市的", name: "尤先生"},
   {place: "來自貴陽市的", name: "陳女士"},
   {place: "來自長春市的", name: "魏女士"},
   {place: "來自泉州市的", name: "褚先生"},
   {place: "來自南昌市的", name: "蔣女士"},
   {place: "來自南京市的", name: "沈先生"},
   {place: "來自天津市的", name: "韓先生"},
   {place: "來自寧波市的", name: "鄒女士"},
   {place: "來自嘉興市的", name: "周女士"},
   {place: "來自長沙市的", name: "秦先生"},
   {place: "來自濟(jì)南市的", name: "孫女士"},
   {place: "來自杭州市的", name: "楊先生"}]
   }
  },
  components:{ marqueeLeft },
 }
</script>

marquee.vue 組件頁面

<template>
 <div class="my-outbox">
  <div class="my-inbox" ref='box'>
   <div class="my-list" v-for="(item,index) in sendVal" :key='index' ref='list'>
    {{item.place}}<span class="my-uname">{{item.name}}</span>剛剛購買了產(chǎn)品
   </div>
  </div>
 </div>
</template>

<script>
 export default {
  name:'my-marquee-left',
  props:{  
   sendVal:Array
  },
  data() {
   return {
    nowTime:null,//定時(shí)器標(biāo)識
    disArr:[],//每一個(gè)內(nèi)容的寬度
   }
  }, 
  mounted:function(){
   var that = this;
   var item = this.$refs.list; 
   var len = this.sendVal.length;
   var arr = [];
   var margin = this.getMargin(item[0]) //因?yàn)樵O(shè)置的margin值一樣,所以取第一個(gè)就行。
   for(var i = 0;i < len;i++){
    arr.push(item[i].clientWidth + margin)//把寬度和 margin 加起來就是每一個(gè)元素需要移動的距離
   }
   this.disArr = arr;
   this.moveLeft();
  },
  beforeDestroy:function(){
   clearInterval(this.nowTime);//頁面關(guān)閉清除定時(shí)器
   this.nowTime = null;//清除定時(shí)器標(biāo)識
  },
  methods:{
   //獲取margin屬性
   getMargin:function(obj){
    var marg = window.getComputedStyle(obj,null)['margin-right'];
    marg = marg.replace('px','')
    return Number(marg) //強(qiáng)制轉(zhuǎn)化成數(shù)字
   },
   //移動的方法
   moveLeft:function(){
    var outbox = this.$refs.box;
    var that=this;
    var startDis = 0;//初始位置
    this.nowTime = setInterval(function(){
     startDis -= 0.5;
     if(Math.abs(startDis) > Math.abs(that.disArr[0])){
      that.disArr.push(that.disArr.shift())//每次移動完一個(gè)元素的距離,就把這個(gè)元素的寬度
      that.sendVal.push(that.sendVal.shift())//每次移動完一個(gè)元素的距離,就把列表數(shù)據(jù)的第一項(xiàng)放到最后一項(xiàng)
      startDis = 0;
     }
     outbox.style = 'transform: translateX('+ startDis +'px)'; //每次都讓盒子移動指定的距離
    },1000/60)
   }
  }
 }
</script>

<style lang="less" scoped>
 .my-outbox{
  color: #D7BC8D;
  overflow: hidden;
  height: 35px;
  background: #422b02;
  .my-inbox{
   white-space: nowrap;
   .my-list{
    margin-right: 25px;
    display: inline-block;
    font-size: 13px;
    height: 35px;
    line-height: 35px;
    .my-uname{
     color: #FF8900;
    }
   }
  }
 }
</style>

(1) 添加一個(gè)獲取margin的方法,是為了保證如果是使用 rem em 等單位時(shí),margin值不會出現(xiàn)偏差的情況

(2) 如果引入組件的頁面中,send-val的值是異步請求的。那么,在marquee.vue組件頁面,多數(shù)情況會獲取不了 refs 。這時(shí)候我自己的解決方法是:

<marqueeLeft :send-val='send' v-if='send'></marqueeLeft >

 表示只有當(dāng) send 不為空的時(shí)候才渲染該組件,不過這種情況會導(dǎo)致如果 請求響應(yīng)太慢,組件會一直渲染不出來,就可能會影響布局。

(3) 如果不想每次都去設(shè)置transform,那么可以把transform放到該元素上,然后修改data中的數(shù)據(jù)就行了,比如:

<div class="my-inbox" :style='transform: translateX('+ cssStyle +'px)'></div>
// 然后在 js 中把 每次移動的值,賦值給cssStyle就行了。不過我感覺這種沒什么區(qū)別

 如果想實(shí)現(xiàn),上下無縫滾動,這種效果。思路和左右無縫滾動一樣,基本上只需要把 transform 改成 Y軸移動 ,每個(gè)列表的寬度改成高度就行了。

不清楚這種方式實(shí)現(xiàn)是否會有什么問題,F(xiàn)PS一直保持在 接近60左右。暫時(shí)沒發(fā)現(xiàn)什么缺點(diǎn)。。。

以上所述是小編給大家介紹的vue自定義marquee無縫滾動組件詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • vue-router報(bào)錯(cuò):uncaught error during route navigati問題及解決

    vue-router報(bào)錯(cuò):uncaught error during route 

    這篇文章主要介紹了vue-router報(bào)錯(cuò):uncaught error during route navigati問題及解決方案,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • vue插件tab選項(xiàng)卡使用小結(jié)

    vue插件tab選項(xiàng)卡使用小結(jié)

    這篇文章主要為大家詳細(xì)介紹了vue插件tab選項(xiàng)卡的使用方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • el-select自定義指令實(shí)現(xiàn)觸底加載分頁請求options數(shù)據(jù)(完整代碼和接口可直接用)

    el-select自定義指令實(shí)現(xiàn)觸底加載分頁請求options數(shù)據(jù)(完整代碼和接口可直接用)

    某些情況下,下拉框需要做觸底加載,發(fā)請求,獲取option的數(shù)據(jù),下面給大家分享el-select自定義指令實(shí)現(xiàn)觸底加載分頁請求options數(shù)據(jù)(附上完整代碼和接口可直接用),感興趣的朋友參考下吧
    2024-02-02
  • vue中wangEditor5編輯器的基本使用

    vue中wangEditor5編輯器的基本使用

    wangEditor是一個(gè)輕量級web富文本編輯器,配置方便,使用簡單,下面這篇文章主要給大家介紹了關(guān)于vue中wangEditor5編輯器的基本使用,文中通過圖文以及實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2023-03-03
  • vue實(shí)現(xiàn)可移動的懸浮按鈕

    vue實(shí)現(xiàn)可移動的懸浮按鈕

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)可移動的懸浮按鈕,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2021-03-03
  • 使用ElementUI中el-upload上傳文件轉(zhuǎn)base64格式

    使用ElementUI中el-upload上傳文件轉(zhuǎn)base64格式

    這篇文章主要介紹了使用ElementUI中el-upload上傳文件轉(zhuǎn)base64格式,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-05-05
  • Vue通過Blob對象實(shí)現(xiàn)導(dǎo)出Excel功能示例代碼

    Vue通過Blob對象實(shí)現(xiàn)導(dǎo)出Excel功能示例代碼

    這篇文章主要介紹了Vue通過Blob對象實(shí)現(xiàn)導(dǎo)出Excel功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • vue項(xiàng)目開發(fā)環(huán)境工具node搭建過程

    vue項(xiàng)目開發(fā)環(huán)境工具node搭建過程

    最近在開始接觸做vue框架的前端項(xiàng)目,以前用的前端比如html,js,css等都是比較原生的,寫好后直接瀏覽器打開就行,今天就先記錄一下vue的開發(fā)運(yùn)行搭建過程,感興趣的朋友一起看看吧
    2023-09-09
  • vue-cli3.0.4中webpack的dist路徑如何修改

    vue-cli3.0.4中webpack的dist路徑如何修改

    這篇文章主要介紹了vue-cli3.0.4中webpack的dist路徑如何修改,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vant中的toast層級改變操作

    vant中的toast層級改變操作

    這篇文章主要介紹了vant中的toast層級改變操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-11-11

最新評論