亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Vue學(xué)習(xí)筆記進(jìn)階篇之列表過(guò)渡及其他

 更新時(shí)間:2017年07月17日 15:27:50   作者:Chain  
本篇文章主要介紹了詳解Vue學(xué)習(xí)筆記進(jìn)階篇之列表過(guò)渡及其他,具有一定的參考價(jià)值,有興趣的可以了解一下

本文將介紹Vue中的列表過(guò)渡,動(dòng)態(tài)過(guò)渡, 以及可復(fù)用過(guò)渡是實(shí)現(xiàn)。

列表過(guò)渡

目前為止,關(guān)于過(guò)渡我們已經(jīng)講到:

  1. 單個(gè)節(jié)點(diǎn)
  2. 同一時(shí)間渲染多個(gè)節(jié)點(diǎn)中的一個(gè)

那么怎么同時(shí)渲染整個(gè)列表,比如使用 v-for ?在這種場(chǎng)景中,使用 <transition-group>組件。在我們深入例子之前,先了解關(guān)于這個(gè)組件的幾個(gè)特點(diǎn):

  1. 不同于 <transition>, 它會(huì)以一個(gè)真實(shí)元素呈現(xiàn):默認(rèn)為一個(gè)<span>。你也可以通過(guò) tag 特性更換為其他元素。
  2. 內(nèi)部元素 總是需要 提供唯一的 key屬性值.列表的進(jìn)入和離開(kāi)過(guò)渡

現(xiàn)在讓我們由一個(gè)簡(jiǎn)單的例子深入,進(jìn)入和離開(kāi)的過(guò)渡使用之前一樣的 CSS 類(lèi)名。

<div id="app1">
  <button @click="add">Add</button>
  <button @click="remove">Remove</button>
  <transition-group name="list" tag="p">
    <span v-for="item in items" :key="item" class="list-item">
      {{item}}
    </span>
  </transition-group>
</div>
.list-item{
      display: inline-block;
      margin-right: 10px;
    }
    .list-enter-active, .list-leave-active{
      transition: all 1s;
    }
    .list-enter, .list-leave-to{
      opacity: 0;
      transform: translateY(30px);
    }
var app1 = new Vue({
  el:'#app1',
  data:{
    items:[1,2,3,4,5,6,7,8,9],
    nextNum:10
  },
  methods:{
    randomIndex:function () {
      return Math.floor(Math.random() * this.items.length)
    },
    add:function () {
      this.items.splice(this.randomIndex(), 0, this.nextNum++)
    },
    remove:function () {
      this.items.splice(this.randomIndex(), 1)
    }
  }
})

運(yùn)行結(jié)果:


這個(gè)例子有個(gè)問(wèn)題,當(dāng)添加和移除元素的時(shí)候,周?chē)脑貢?huì)瞬間移動(dòng)到他們的新布局的位置,而不是平滑的過(guò)渡,我們下面會(huì)解決這個(gè)問(wèn)題。

列表的位移過(guò)渡

<transition-group> 組件還有一個(gè)特殊之處。不僅可以進(jìn)入和離開(kāi)動(dòng)畫(huà),還可以改變定位。要使用這個(gè)新功能只需了解新增的v-move 特性,它會(huì)在元素的改變定位的過(guò)程中應(yīng)用。像之前的類(lèi)名一樣,可以通過(guò) name 屬性來(lái)自定義前綴,也可以通過(guò) move-class 屬性手動(dòng)設(shè)置。

v-move對(duì)于設(shè)置過(guò)渡的切換時(shí)機(jī)和過(guò)渡曲線(xiàn)非常有用,你會(huì)看到如下的例子:

<div id="app2">
  <button @click="shuffle">Shuffle</button>
  <transition-group name="flip-list" tag="ul">
    <li v-for="item in items" :key="item">
      {{item}}
    </li>
  </transition-group>
</div>
.flip-list-move {
   transition: transform 1s;
}
var app2 = new Vue({
  el:'#app2',
  data:{
    items:[1,2,3,4,5,6,7,8,9]
  },
  methods:{
    shuffle:function () {
      this.items = _.shuffle(this.items)
    }
  }
})

這個(gè)例子需要添加以下引用

<script src="https://cdnjs.cloudflare.com/ajax/libs/lodash.js/4.14.1/lodash.min.js"></script>

運(yùn)行結(jié)果:


這個(gè)看起來(lái)很神奇,內(nèi)部的實(shí)現(xiàn),Vue 使用了一個(gè)叫 FLIP 簡(jiǎn)單的動(dòng)畫(huà)隊(duì)列

使用 transforms 將元素從之前的位置平滑過(guò)渡新的位置。

我們將之前實(shí)現(xiàn)的例子和這個(gè)技術(shù)結(jié)合,使我們列表的一切變動(dòng)都會(huì)有動(dòng)畫(huà)過(guò)渡。

<div id="app3" class="demo">
  <button @click="shuffle">Shuffle</button>
  <button @click="add">Add</button>
  <button @click="remove">Remove</button>
  <transition-group name="list-complete" tag="p">
    <span v-for="item in items" :key="item" class="list-complete-item">
      {{item}}
    </span>
  </transition-group>
</div>
.list-complete-item{
  transition: all 1s;
  display: inline-block;
  margin-right: 10px;
}
.list-complete-enter, .list-complete-leave-to{
  opacity: 0;
  transform: translateY(30px);
}
.list-complete-leave-active{
  position: absolute;
}
var app3 = new Vue({
  el:'#app3',
  data:{
    items:[1,2,3,4,5,6,7,8,9],
    nextNum:10
  },
  methods:{
    shuffle:function () {
      this.items = _.shuffle(this.items)
    },
    randomIndex:function () {
      return Math.floor(Math.random() * this.items.length)
    },
    add:function () {
      this.items.splice(this.randomIndex(), 0, this.nextNum++)
    },
    remove:function () {
      this.items.splice(this.randomIndex(), 1)
    }
  }
})

運(yùn)行結(jié)果:


列表的漸進(jìn)過(guò)渡

通過(guò) data 屬性與 JavaScript 通信 ,就可以實(shí)現(xiàn)列表的漸進(jìn)過(guò)渡:

<div id="app4">
  <input v-model="query">
  <transition-group
    name="staggered-fade"
    tag="ul"
    :css="false"
    @before-enter="beforeEnter"
    @enter="enter"
    @leave="leave">
    <li v-for="(item, index) in computedList"
      :key="item.msg"
      :data-index="index">
      {{item.msg}}
    </li>
  </transition-group>
</div>
var app4 = new Vue({
  el:'#app4',
  data:{
    query:'',
    list:[
      {msg:'Bruce Lee'},
      {msg:'Jackie Chan'},
      {msg:'Chuck Norris'},
      {msg:'Jet Li'},
      {msg:'Kung Furry'},
      {msg:'Chain Zhang'},
      {msg:'Iris Zhao'},
    ]
  },
  computed:{
    computedList:function () {
      var vm = this
      return this.list.filter(function (item) {
        return item.msg.toLowerCase().indexOf(vm.query.toLowerCase()) !== -1
      })
    }
  },
  methods:{
    beforeEnter:function (el) {
      el.style.opacity = 0
      el.style.height = 0
    },
    enter:function (el, done) {
      var delay = el.dataset.index * 150
      setTimeout(function () {
        Velocity(el, {opacity:1, height:'1.6em'},{complete:done})
      }, delay)
    },
    leave:function (el, done) {
      var delay = el.dataset.index * 150
      setTimeout(function () {
        Velocity(el, {opacity:0, height:0}, {complete:done})
      }, delay)
    }
  }
})

上述js代碼需要添加對(duì)Velocity引用:

<script src="https://cdnjs.cloudflare.com/ajax/libs/velocity/1.2.3/velocity.min.js"></script>

運(yùn)行結(jié)果如下:


可復(fù)用的過(guò)渡

過(guò)渡可以通過(guò) Vue 的組件系統(tǒng)實(shí)現(xiàn)復(fù)用。要?jiǎng)?chuàng)建一個(gè)可復(fù)用過(guò)渡組件,你需要做的就是將<transition>或者 <transition-group>作為根組件,然后將任何子組件放置在其中就可以了。

下面的例子是將上一個(gè)列表漸進(jìn)過(guò)渡的例子改為可復(fù)用的過(guò)渡的源碼:

<div id="app5">
  <input v-model="query">
  <my-transition :query="query" :list="list">
    <li v-for="(item, index) in computedList"
      :key="item.msg"
      :data-index="index">
      {{item.msg}}
    </li>
  </my-transition>
</div>
Vue.component('my-transition', {
  template:`
  <transition-group
    name="staggered-fade"
    tag="ul"
    :css="false"
    @before-enter="beforeEnter"
    @enter="enter"
    @leave="leave">
    <slot></slot>
  </transition-group>`,
  props:['query', 'list'],
  methods:{
    beforeEnter:function (el) {
      el.style.opacity = 0
      el.style.height = 0
    },
    enter:function (el, done) {
      var delay = el.dataset.index * 150
      setTimeout(function () {
        Velocity(el, {opacity:1, height:'1.6em'},{complete:done})
      }, delay)
    },
    leave:function (el, done) {
      var delay = el.dataset.index * 150
      setTimeout(function () {
        Velocity(el, {opacity:0, height:0}, {complete:done})
      }, delay)
    }
  }
})

var app5 = new Vue({
  el:'#app5',
  data:{
    query:'',
    list:[
      {msg:'Bruce Lee'},
      {msg:'Jackie Chan'},
      {msg:'Chuck Norris'},
      {msg:'Jet Li'},
      {msg:'Kung Furry'},
      {msg:'Chain Zhang'},
      {msg:'Iris Zhao'},
    ]
  },
  computed:{
    computedList:function () {
      var vm = this
      return this.list.filter(function (item) {
        return item.msg.toLowerCase().indexOf(vm.query.toLowerCase()) !== -1
      })
    }
  },
})

效果與上一個(gè)例子一致:


但是函數(shù)組件更適合完成這個(gè)任務(wù)。由于暫時(shí)還沒(méi)有學(xué)到render函數(shù),所以暫時(shí)先不實(shí)現(xiàn)render函數(shù)組件。后面學(xué)到的時(shí)候再做打算。

動(dòng)態(tài)過(guò)渡

在 Vue 中即使是過(guò)渡也是數(shù)據(jù)驅(qū)動(dòng)的!動(dòng)態(tài)過(guò)渡最基本的例子是通過(guò) name 特性來(lái)綁定動(dòng)態(tài)值。

<transition v-bind:name="transitionName">
 <!-- ... -->
</transition>

當(dāng)你想用 Vue 的過(guò)渡系統(tǒng)來(lái)定義的 CSS 過(guò)渡/動(dòng)畫(huà) 在不同過(guò)渡間切換會(huì)非常有用。

所有的過(guò)渡特性都是動(dòng)態(tài)綁定。它不僅是簡(jiǎn)單的特性,通過(guò)事件的鉤子函數(shù)方法,可以在獲取到相應(yīng)上下文數(shù)據(jù)。這意味著,可以根據(jù)組件的狀態(tài)通過(guò) JavaScript 過(guò)渡設(shè)置不同的過(guò)渡效果。

<div id="app6">
  Fade In:
  <input type="range" v-model="fadeInDuration" min="0" :max="maxFadeDuration">
  Fade Out:
  <input type="range" v-model="fadeOutDuration" min="0" :max="maxFadeDuration">
  <transition
    v-bind:css="false"
    @before-enter="beforeEnter"
    @enter="enter"
    @leave="leave">
    <p v-if="show">hello chain</p>
  </transition>
  <button @click="stop = true">Stop it</button>
</div>
var app6 = new Vue({
  el: '#app6',
  data: {
    show: true,
    fadeInDuration: 1000,
    fadeOutDuration: 1000,
    maxFadeDuration: 1500,
    stop: false
  },
  mounted: function () {
    this.show = false
  },
  methods: {
    beforeEnter: function (el) {
      el.style.opacity = 0
    },
    enter: function (el, done) {
      var vm = this
      Velocity(el,
        { opacity: 1 },
        {
          duration: this.fadeInDuration,
          complete: function () {
            done()
            if (!vm.stop) vm.show = false
          }
        }
      )
    },
    leave: function (el, done) {
      var vm = this
      Velocity(el,
        { opacity: 0 },
        {
          duration: this.fadeOutDuration,
          complete: function () {
            done()
            vm.show = true
          }
        }
      )
    }
  }
})

運(yùn)行結(jié)果:


其中例子里的mounted是在Vue掛載完成,也就是模板中的html渲染到html頁(yè)面中時(shí)的一個(gè)鉤子函數(shù),只會(huì)執(zhí)行一次。具體內(nèi)容可以理解下Vue的生命周期,這里就不贅述了。

但是如果這里不使用mounted的話(huà),也是可以用初始渲染來(lái)實(shí)現(xiàn),只不過(guò)比較麻煩。實(shí)現(xiàn)的方法是:

在transition中加入appear鉤子函數(shù):@appear="appear",然后在vue實(shí)例的methods中添加appear方法:

appear: function (el, done) {
      var vm = this
      Velocity(el,
        { opacity: 1 },
        {
          duration: this.fadeInDuration,
          complete: function () {
            done()
            if (!vm.stop) vm.show = false
          }
        }
      )
    }

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • vue的無(wú)縫滾動(dòng)組件vue-seamless-scroll實(shí)例

    vue的無(wú)縫滾動(dòng)組件vue-seamless-scroll實(shí)例

    本篇文章主要給大家講解了vue的無(wú)縫滾動(dòng)組件vue-seamless-scroll的用法,需要的朋友參考學(xué)習(xí)下吧。
    2017-12-12
  • vue跳轉(zhuǎn)方式的常見(jiàn)方式以及區(qū)別分析

    vue跳轉(zhuǎn)方式的常見(jiàn)方式以及區(qū)別分析

    在Vue.js中頁(yè)面跳轉(zhuǎn)是前端開(kāi)發(fā)中常見(jiàn)的需求,Vue提供了多種頁(yè)面跳轉(zhuǎn)方式,這篇文章主要給大家介紹了關(guān)于vue跳轉(zhuǎn)方式的常見(jiàn)方式以及區(qū)別分析的相關(guān)資料,需要的朋友可以參考下
    2024-02-02
  • vue3關(guān)于RouterView插槽和過(guò)渡動(dòng)效

    vue3關(guān)于RouterView插槽和過(guò)渡動(dòng)效

    這篇文章主要介紹了vue3關(guān)于RouterView插槽和過(guò)渡動(dòng)效,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-06-06
  • vue3 微信掃碼登錄及獲取個(gè)人信息實(shí)現(xiàn)的三種方法

    vue3 微信掃碼登錄及獲取個(gè)人信息實(shí)現(xiàn)的三種方法

    本文主要介紹了vue3 微信掃碼登錄及獲取個(gè)人信息實(shí)現(xiàn)的三種方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-03-03
  • Vue.js移動(dòng)端左滑刪除組件的實(shí)現(xiàn)代碼

    Vue.js移動(dòng)端左滑刪除組件的實(shí)現(xiàn)代碼

    本篇文章主要介紹了Vue.js移動(dòng)端左滑刪除組件的實(shí)現(xiàn)代碼,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2017-09-09
  • Vue如何動(dòng)態(tài)修改el-table的某列數(shù)據(jù)

    Vue如何動(dòng)態(tài)修改el-table的某列數(shù)據(jù)

    這篇文章主要介紹了Vue如何動(dòng)態(tài)修改el-table的某列數(shù)據(jù),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04
  • vue 項(xiàng)目中實(shí)現(xiàn)按鈕防抖方法

    vue 項(xiàng)目中實(shí)現(xiàn)按鈕防抖方法

    這篇文章主要介紹了vue 項(xiàng)目中實(shí)現(xiàn)按鈕防抖方法,首先需要新建 .js文件存放防抖方法,引入防抖文件,methods中添加方法,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2022-12-12
  • Vue實(shí)現(xiàn)登錄以及登出詳解

    Vue實(shí)現(xiàn)登錄以及登出詳解

    本篇文章主要介紹了vue實(shí)現(xiàn)登陸登出的實(shí)現(xiàn)示例,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2021-09-09
  • vue如何關(guān)閉prettier警告warn

    vue如何關(guān)閉prettier警告warn

    這篇文章主要介紹了vue如何關(guān)閉prettier警告warn問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue-cli+webpack記事本項(xiàng)目創(chuàng)建

    vue-cli+webpack記事本項(xiàng)目創(chuàng)建

    這篇文章主要為大家詳細(xì)介紹了vue-cli+webpack創(chuàng)建記事本項(xiàng)目,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-04-04

最新評(píng)論