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

vue 動(dòng)態(tài)組件用法示例小結(jié)

 更新時(shí)間:2020年03月06日 10:57:46   作者:程序媛-jjl  
這篇文章主要介紹了vue 動(dòng)態(tài)組件用法,結(jié)合實(shí)例形式總結(jié)分析了vue 動(dòng)態(tài)組件基本功能、原理、使用方法及操作注意事項(xiàng),需要的朋友可以參考下

本文實(shí)例講述了vue 動(dòng)態(tài)組件用法。分享給大家供大家參考,具體如下:

通過使用保留的 <component> 元素,動(dòng)態(tài)地綁定到它的 is 特性,我們讓多個(gè)組件可以使用同一個(gè)掛載點(diǎn),并動(dòng)態(tài)切換。根據(jù) v-bind:is="組件名" 中的組件名去自動(dòng)匹配組件,如果匹配不到則不顯示。

改變掛載的組件,只需要修改is指令的值即可。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
<div id="app">
 <button @click='toShow'>點(diǎn)擊顯示子組件</button>
 <component v-bind:is="which_to_show"></component>
</div>

<script>

// 創(chuàng)建根實(shí)例
new Vue({
 el: '#app',
 data:{
  which_to_show:'first'
 },
 methods:{
 toShow:function(){
  var arr = ["first","second","third"];
  var index = arr.indexOf(this.which_to_show);
  if(index<2){
  this.which_to_show = arr[index+1];
  }else{
  this.which_to_show = arr[0];
  }
 }
 },
 components:{
 first:{
  template:'<div>這是子組件1<div>'
 },
 second:{
  template:'<div>這是子組件2<div>'
 },
 third:{
  template:'<div>這是子組件3<div>'
 },
 }
})
</script>
</body>
</html>

#keep-alive

動(dòng)態(tài)切換掉的組件(非當(dāng)前顯示的組件)是被移除掉了,如果把切換出去的組件保留在內(nèi)存中,可以保留它的狀態(tài)或避免重新渲染。為此可以添加一個(gè) keep-alive 指令參數(shù):

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
<div id="app">
 <button @click='toShow'>點(diǎn)擊顯示子組件</button>
 <!----或者<component v-bind:is="which_to_show" keep-alive></component>也行----->
 <keep-alive>
 <component v-bind:is="which_to_show" ></component>
 </keep-alive>
</div>

<script>

// 創(chuàng)建根實(shí)例
new Vue({
 el: '#app',
 data:{
  which_to_show:'first'
 },
 methods:{
 toShow:function(){
  var arr = ["first","second","third"];
  var index = arr.indexOf(this.which_to_show);
  if(index<2){
  this.which_to_show = arr[index+1];
  }else{
  this.which_to_show = arr[0];
  } console.log(this.$children); 
 }
 },
 components:{
 first:{
  template:'<div>這是子組件1<div>'
 },
 second:{
  template:'<div>這是子組件2<div>'
 },
 third:{
  template:'<div>這是子組件3<div>'
 },
 }
})
</script>
</body>
</html>

說明:

初始情況下,vm.$children屬性中只有一個(gè)元素(first組件),

點(diǎn)擊按鈕切換后,vm.$children屬性中有兩個(gè)元素,

再次切換后,則有三個(gè)元素(三個(gè)子組件都保留在內(nèi)存中)。

之后無論如何切換,將一直保持有三個(gè)元素。

actived鉤子

可以延遲執(zhí)行當(dāng)前的組件。

具體用法來說,activate是和template、data等屬性平級(jí)的一個(gè)屬性,形式是一個(gè)函數(shù),函數(shù)里默認(rèn)有一個(gè)參數(shù),而這個(gè)參數(shù)是一個(gè)函數(shù),執(zhí)行這個(gè)函數(shù)時(shí),才會(huì)切換組件。

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<title>Vue 測(cè)試實(shí)例 - 動(dòng)態(tài)組件</title>
<script src="https://cdn.bootcss.com/vue/2.2.2/vue.min.js"></script>
</head>
<body>
<div id="app">
 <button @click='toShow'>點(diǎn)擊顯示子組件</button>
 <!----或者<component v-bind:is="which_to_show" keep-alive></component>也行----->
 <keep-alive>
 <component v-bind:is="which_to_show" ></component>
 </keep-alive>
</div>

<script>

// 創(chuàng)建根實(shí)例
var vm = new Vue({
    el: '#app',
    data: {
      which_to_show: "first"
    },
    methods: {
      toShow: function () {  //切換組件顯示
        var arr = ["first", "second", "third", ""];
        var index = arr.indexOf(this.which_to_show);
        if (index < 2) {
          this.which_to_show = arr[index + 1];
        } else {
          this.which_to_show = arr[0];
        }
        console.log(this.$children);
      }
    },
    components: {
      first: { //第一個(gè)子組件
        template: "<div>這里是子組件1</div>"
      },
      second: { //第二個(gè)子組件
        template: "<div>這里是子組件2,這里是延遲后的內(nèi)容:{{hello}}</div>",
        data: function () {
          return {
            hello: ""
          }
        },
        activated: function (done) { //執(zhí)行這個(gè)參數(shù)時(shí),才會(huì)切換組件
   console.log('hhh')
          var self = this;
   var startTime = new Date().getTime(); // get the current time
   //兩秒后執(zhí)行
          while (new Date().getTime() < startTime + 2000){
   self.hello='我是延遲后的內(nèi)容';
   }

        }
      },
      third: { //第三個(gè)子組件
        template: "<div>這里是子組件3</div>"
      }
    }
  });
</script>
</body>
</html>

當(dāng)切換到第二個(gè)組件的時(shí)候,會(huì)先執(zhí)行activated鉤子,會(huì)在兩秒后顯示組件2.起到了延遲加載的作用。

希望本文所述對(duì)大家vue.js程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • 你了解vue3.0響應(yīng)式數(shù)據(jù)怎么實(shí)現(xiàn)嗎

    你了解vue3.0響應(yīng)式數(shù)據(jù)怎么實(shí)現(xiàn)嗎

    這篇文章主要介紹了你了解vue3.0響應(yīng)式數(shù)據(jù)怎么實(shí)現(xiàn)嗎,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2019-06-06
  • Vue不能檢測(cè)到Object/Array更新的情況的解決

    Vue不能檢測(cè)到Object/Array更新的情況的解決

    本篇文章主要介紹了Vue不能檢測(cè)到Object/Array更新的情況的解決,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • Vue3中實(shí)現(xiàn)網(wǎng)頁時(shí)鐘功能(顯示當(dāng)前時(shí)間并每秒更新一次)

    Vue3中實(shí)現(xiàn)網(wǎng)頁時(shí)鐘功能(顯示當(dāng)前時(shí)間并每秒更新一次)

    本文將詳細(xì)介紹如何在Vue3中實(shí)現(xiàn)一個(gè)每秒鐘自動(dòng)更新的網(wǎng)頁時(shí)鐘,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-07-07
  • vue和react中關(guān)于插槽詳解

    vue和react中關(guān)于插槽詳解

    這篇文章主要介紹了vue和react中關(guān)于插槽詳解,slot插槽是Vue對(duì)組件嵌套這種擴(kuò)展機(jī)制的稱謂,在react可以也這樣稱呼,但是并不很常見。不過叫slot確實(shí)很形象
    2022-08-08
  • Vue中@click.stop與@click.prevent、@click.native使用

    Vue中@click.stop與@click.prevent、@click.native使用

    這篇文章主要介紹了Vue中@click.stop與@click.prevent、@click.native使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-08-08
  • Vuejs第九篇之組件作用域及props數(shù)據(jù)傳遞實(shí)例詳解

    Vuejs第九篇之組件作用域及props數(shù)據(jù)傳遞實(shí)例詳解

    這篇文章主要介紹了Vuejs第九篇之組件作用域及props數(shù)據(jù)傳遞實(shí)例詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-09-09
  • vue.js學(xué)習(xí)之遞歸組件

    vue.js學(xué)習(xí)之遞歸組件

    最近學(xué)習(xí)vue.js有一段時(shí)間了,使用vue做了一套后臺(tái)管理系統(tǒng),其中使用最多就是遞歸組件,也因?yàn)樽约簩?duì)官方文檔的不熟悉使得自己踩了不少坑,所以今天寫出來和大家一起分享。有需要的朋友們可以參考借鑒,下面來一起看看吧。
    2016-12-12
  • vue項(xiàng)目配置國際化$t('')的介紹和用法示例

    vue項(xiàng)目配置國際化$t('')的介紹和用法示例

    這篇文章主要給大家介紹了關(guān)于vue項(xiàng)目配置國際化?$t('')的介紹和用法的相關(guān)資料,多語言和國際化現(xiàn)在已經(jīng)成為一個(gè)網(wǎng)站或應(yīng)用的必要功能之一,Vue作為一款流行的前端框架,在這方面也有著靈活的解決方案,需要的朋友可以參考下
    2023-09-09
  • el-table樹形數(shù)據(jù)量過大,導(dǎo)致頁面卡頓問題及解決

    el-table樹形數(shù)據(jù)量過大,導(dǎo)致頁面卡頓問題及解決

    這篇文章主要介紹了el-table樹形數(shù)據(jù)量過大,導(dǎo)致頁面卡頓問題及解決,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-04-04
  • vue填坑之webpack run build 靜態(tài)資源找不到的解決方法

    vue填坑之webpack run build 靜態(tài)資源找不到的解決方法

    今天小編就為大家分享一篇vue填坑之webpack run build 靜態(tài)資源找不到的解決方法。具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09

最新評(píng)論