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

Vue學習之組件用法實例詳解

 更新時間:2020年01月06日 10:48:11   作者:theVicTory  
這篇文章主要介紹了Vue學習之組件用法,結(jié)合實例形式分析了vue.js組件的使用流程、模板、父子組件、插槽slot等相關(guān)原理與操作技巧,需要的朋友可以參考下

本文實例講述了Vue學習之組件用法。分享給大家供大家參考,具體如下:

Vue中的模塊化、可重用代碼塊將頁面細分為一個個功能組件,而且組件之間可以嵌套。組件分為全局組件與局部組件,局部組件在實例中進行注冊,并且只可以應用于該實例中。

1、 組件的使用流程:

  //1、創(chuàng)建組件構(gòu)造器
    let overallDiv=Vue.extend({
      template:`
        <div>
          <p>這是一個全局組件div</p>
        </div>
      `
    });
  //2、注冊全局組件
    Vue.component('overall-div',overallDiv);
  //3、實例化,組件只有在實例化的div內(nèi)才能使用,不可以直接在頁面中使用
    let vue=new Vue({
      el:'#app',
      data:{},
    //在實例內(nèi)注冊局部組件,其創(chuàng)建與注冊可以合為一步來寫
    components:{
      'local-div':{
        template:
          ` <div>
              <p>這是一個局部組件div</p>
           </div>
          `
      }
    },
    methods:{
    }
    });

在HTML頁面實例化的div中使用組件:

  <div id="app">
    <local-div></local-div>
    <overall-div></overall-div>
  </div>

注意:一些HTML標簽對放入其中的標簽有限制,這時需要通過is屬性將組件轉(zhuǎn)化為你要放入的組件,例如<ul>標簽下只能放<li>,這時,你可以使用<li is="my-component">,這樣就相當于放入了<my-component>標簽。

2、template模板

組件的模板除了在js中創(chuàng)建外,還可以使用頁面中的template創(chuàng)建模板,注意頁面中的模板只能有一個根元素,如有多個元素需要包含在一個div內(nèi),例如頁面body中的模板:

  <template id="myTmp">
    <div>
      <p>這是頁面中的模板</p>
    </div>
  </template>

在js中通過id號注冊模板。

  Vue.component('my-tmp',{
    template:'#myTmp'
  });

3、組件的data

在組件中使用data必須以函數(shù)的形式返回,如果以屬性值的形式存在,所有的組件會共享一個屬性值,更改其中一個,所有的組件都會收到影響。例如一個統(tǒng)計被點擊次數(shù)的組件:

  <template id="myBtn">
    <div>
      <button @click="count++">按鈕被點擊{{count}}次</button>
    </div>
  </template>

  Vue.component('my-btn',{
    template:'#myBtn',
    data () {    //以函數(shù)返回的方式定義組件使用的data
      return {
        count:0
      };
    }
  });   
  <div id="app">
    <my-btn></my-btn>
    <my-btn></my-btn>
  </div>

在頁面中分別點擊兩個按鈕,兩個按鈕組件的count分別計數(shù),不會互相干擾:

4、父子組件

先創(chuàng)建子組件,然后再父組件內(nèi)進行注冊,就可以在父組件的模板內(nèi)使用子組件,然后再注冊父組件,這樣就可以在外部調(diào)用包含子組件的父組件了,外部直接使用父組件接口,而不需要知道內(nèi)部子組件的實現(xiàn)

注意在外部不能直接使用子組件,因為它只在父組件內(nèi)進行了注冊,外部看不到子組件

  let child1=Vue.extend({
    template:`<div>這是子組件1</div>`
  });
  let child2=Vue.extend({
    template:`<div>這是子組件2</div>`
  });
  Vue.component('parent',{
    components:{
      'c1':child1,
      'c2':child2
    },
    //在父組件內(nèi)調(diào)用子組件
    template:`<div>父組件<c1></c1><c2></c2></div>`
  });
  <div id="app">
    <parent></parent>
  </div>

結(jié)果如圖:

5、插槽slot

像生活中的容器一樣,slot允許向其中插入標簽、組件等內(nèi)容,而在外部提供一個框子包裝起來。slot分為匿名插槽與實名插槽,匿名插槽可以向其中插入任何類型的內(nèi)容。

實名slot可以將內(nèi)容插入指定的插槽內(nèi),就像一臺電腦的主板,cpu、內(nèi)存條分別有自己對應的插槽,實名插槽在模板中通過name屬性規(guī)定插槽的名字,在使用時,通過標簽的slot屬性指定對應的name,可以將標簽插入指定的插槽。

匿名插槽

  <!--匿名插槽-->
  <template id="anonymousDiv">
    <div style="width: 20%;">
      <h3>這是插槽頭部</h3>
      <slot>插槽默認顯示內(nèi)容</slot>
      <hr/>
      <p>插槽尾部</p>
    </div>
  </template>
  let vue2=new Vue({
    el:'#app2',
    data:{
    },
    components:{
     //綁定匿名插槽
     'anonymous-slot':{
       template:'#anonymousDiv'
     },
     //綁定實名插槽
     'realname-slot':{
       template:'#realnameDiv'
     }
    }
  });

向cpu插槽內(nèi)插入內(nèi)容:

  <div id="app2">
    <anonymous-slot>
      <p>向插槽中插入一段文字</p>
    </anonymous-slot>
  </div>

插槽未放入內(nèi)容時:插入一段文字:

實名插槽

<template id="realnameDiv">
<div>
  <h3>實名插槽頭部</h3>
  <slot name="cpu">這是cpu插槽</slot>
  <slot name="memery">這是內(nèi)存條插槽</slot>
  <slot name="HardDisk">這是硬盤插槽</slot>
</div>
</template>
<realname-slot>
  <p slot="cpu">Intel Core i5</p>
</realname-slot>

結(jié)果:cpu放入指定插槽,而其他插槽未受影響:

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

相關(guān)文章

  • vue把頁面轉(zhuǎn)換成圖片導出方式(html2canvas導出不全問題)

    vue把頁面轉(zhuǎn)換成圖片導出方式(html2canvas導出不全問題)

    這篇文章主要介紹了vue把頁面轉(zhuǎn)換成圖片導出方式(html2canvas導出不全問題),具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue 短信驗證碼組件開發(fā)詳解

    Vue 短信驗證碼組件開發(fā)詳解

    Vue.js(讀音 /vju&#720;/, 類似于 view)是一個構(gòu)建數(shù)據(jù)驅(qū)動的 web 界面的庫。這篇文章主要介紹了Vue 短信驗證碼組件開發(fā)詳解,需要的朋友可以參考下
    2017-02-02
  • <el-button>點擊后如何跳轉(zhuǎn)指定url鏈接

    <el-button>點擊后如何跳轉(zhuǎn)指定url鏈接

    這篇文章主要介紹了<el-button>點擊后如何跳轉(zhuǎn)指定url鏈接問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vue.js初學入門教程(1)

    vue.js初學入門教程(1)

    這篇文章主要為大家詳細介紹了vue.js初學入門教程,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-11-11
  • Vue3之修改端口號方式

    Vue3之修改端口號方式

    這篇文章主要介紹了Vue3之修改端口號方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • 12 種使用Vue 的最佳做法

    12 種使用Vue 的最佳做法

    這篇文章主要介紹了12 種使用Vue 的最佳做法,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-03-03
  • vue中v-bind與v-model的區(qū)別舉例詳解

    vue中v-bind與v-model的區(qū)別舉例詳解

    這篇文章主要給大家介紹了關(guān)于vue中v-bind與v-model區(qū)別的相關(guān)資料,v-model和v-bind是Vue.js框架中的兩個常用指令,文中通過圖文介紹的非常詳細,需要的朋友可以參考下
    2023-09-09
  • 如何測量vue應用運行時的性能

    如何測量vue應用運行時的性能

    這篇文章主要介紹了如何測量vue應用運行時的性能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,,需要的朋友可以參考下
    2019-06-06
  • 最新評論