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

解讀Vue組件注冊方式

 更新時間:2021年05月15日 14:24:39   作者:lovin  
無論是Vue還是React,都有組件的概念。組件,就是能和別人組合在一起的物件。在前端頁面開發(fā)過程中,將一個頁面劃分成一個個小的模塊,每個模塊單獨定義,每個模塊就是一個組件。組件可以進行復(fù)用,A頁面和B頁面有一個相似的模塊,可以抽離成一個可局部修改的組件。

概述

組件化的概念讓前端頁面開發(fā)有了更清晰的結(jié)構(gòu)。

Vue 中的組件就是一個 Vue 的實例對象。因此,Vue 組件的構(gòu)造選項和 new Vue() 方法構(gòu)造 Vue 實例的構(gòu)造選項是一樣的,其可接收的構(gòu)造選項都是一樣的。除了 el 這樣 根實例 特有的選項。但是,Vue 組件必須得是可以復(fù)用的,因此,就必須要求構(gòu)造選項中的 data 選項必須是一個函數(shù),該函數(shù)返回一個對象。

為什么 data 選項是個返回對象的函數(shù)就可以保證組件的可復(fù)用性呢?

因為無論是 new Vue() 的方式還是定義 Vue組件 的方式創(chuàng)建一個 Vue 實例,其執(zhí)行的操作都是將構(gòu)造選項中的各屬性值直接賦值給新創(chuàng)建的 Vue 實例對象。組件復(fù)用就是 Vue 使用 相同的構(gòu)造選項 構(gòu)造出多個同名不同地址的 Vue 實例對象。如果 Vue 組件定義時的構(gòu)造選項中的 data 選項是一個對象,那么在組件復(fù)用時,多個組件就會共用一個 data 數(shù)據(jù)對象,因為是直接將 data 對象的地址賦值給組件的 Vue 實例的。但如果組件定義時的 data 選項是一個函數(shù)的話,那么 Vue 根據(jù)構(gòu)造選項創(chuàng)建組件時會執(zhí)行該函數(shù)從而得到一個對象。這樣一來,每次創(chuàng)建 Vue 實例時的 data 對象都是重新生成的,因此,多個組件都有各自的 data 數(shù)據(jù)對象,不會相互影響。

實際上,在組件注冊時是在定義組件的構(gòu)造選項,在組件使用時才真正創(chuàng)建對應(yīng)的 Vue 組件實例。

1 、全局注冊

全局注冊的組件可以在 Vue 根實例和所有的子組件中使用。注冊入口為Vue.component()函數(shù),一次注冊,隨時使用,注冊方式如下:

Vue.component('my-component-name',{ 
    options 
})

示例如下:

//main.js
//此示例是在 vue-cli 創(chuàng)建的項目,默認(rèn)是非完整版vue,無法用 template 選項,因此使用 render 函數(shù)寫組件內(nèi)容。
Vue.component('all-test',{
  data(){
    return {
      x: '我是全局組件'
    }
  },
  render(h){
    return h('div',this.x)
  }
})

//全局注冊的組件直接使用即可
//App.vue
<template>
  <div id="app">
    <all-test />
  </div>
</template>

2 、局部注冊

局部注冊是通過一個普通的 JavaScript 對象來定義組件。然后組件的命名和注冊入口是在 Vue實例 構(gòu)造選項中的 components 選項。

let component = { options }

//new Vue 創(chuàng)建的根元素 Vue 實例
new Vue({
    el: '#app'
    components: {
        'my-component-name': component
    }
})

//或注冊 Vue組件 創(chuàng)建的 Vue 實例
export default {
    components: {
        'my-component-name': component
    }
}

示例如下:

//App.vue
<template>
  <div id="app">
    <all-test />
    <component-a />
    <component-b />
  </div>
</template>

<script>
let ComponentA = {
  data(){
    return {
      x: '我是局部組件 A'
    }
  },
  render(h){
    return h('div',this.x)
  }
}

export default {
  name: 'App',
  components: {
    'component-a': ComponentA,
    'component-b': {
        data(){
          return {
            x: '我是局部組件 B'
          }
        },
        render(h){
          return h('div',this.x)
        }
    } 
  }
}
</script>

3 、模塊系統(tǒng)中局部注冊

在使用了諸如 Babel 和 webpack 的模塊系統(tǒng)中可以使用 import 和 export 的方式單獨導(dǎo)入組件的構(gòu)造選項對象 或者 導(dǎo)入對應(yīng)構(gòu)造選項的 *.vue 文件。

//c.js
export default {
    data(){
        return {
          x: '我是 c.js 文件單獨導(dǎo)出的組件構(gòu)造選項對象'
        }
      },
      render(h){
        return h('div',this.x)
      }
}

//D.vue
<template>
    <div>
        {{x}}
    </div>
</template>

<script>
export default {
    data(){
        return {
            x: '我是 D.vue 文件導(dǎo)出的組件'
        }
    }
}
</script>

//App.vue
<template>
  <div id="app">
    <C />
    <D />
  </div>
</template>

import C from './c.js'
import D from './components/D.vue'

export default {
  name: 'App',
  components: {
    C,
    D 
  }
}
</script>

以上就是解讀Vue組件注冊方式的詳細(xì)內(nèi)容,更多關(guān)于Vue組件注冊方式的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • vue文件批量上傳及進度條展示的實現(xiàn)方法

    vue文件批量上傳及進度條展示的實現(xiàn)方法

    開發(fā)項目的時候,用到文件上傳的功能很常見,包括單文件上傳和多文件上傳,下面這篇文章主要給大家介紹了關(guān)于vue文件批量上傳及進度條展示的實現(xiàn)方法,需要的朋友可以參考下
    2022-12-12
  • Vue-router 類似Vuex實現(xiàn)組件化開發(fā)的示例

    Vue-router 類似Vuex實現(xiàn)組件化開發(fā)的示例

    本篇文章主要介紹了Vue-router 類似Vuex實現(xiàn)組件化開發(fā)的示例,具有一定的參考價值,有興趣的可以了解一下
    2017-09-09
  • Vue3使用contenteditable打造定制化輸入

    Vue3使用contenteditable打造定制化輸入

    contenteditable 屬性為網(wǎng)頁開發(fā)者提供了一種靈活的方式來創(chuàng)建可編輯的內(nèi)容區(qū)域,使用戶可以直接在網(wǎng)頁上進行內(nèi)容編輯,而無需依賴傳統(tǒng)的輸入框,本文將利用contenteditable打造定制化輸入,感興趣的可以了解下
    2023-12-12
  • vue里的data要用return返回的原因淺析

    vue里的data要用return返回的原因淺析

    這篇文章主要介紹了vue里的data要用return返回的原因淺析,需要的朋友可以參考下
    2019-05-05
  • 從vue源碼看props的用法

    從vue源碼看props的用法

    平時寫vue的時候知道 props 有很多種用法,今天我們來看看vue內(nèi)部是怎么處理 props 中那么多的用法的。非常具有實用價值,需要的朋友可以參考下
    2019-01-01
  • vue中路由跳轉(zhuǎn)的方式有哪些你知道嗎

    vue中路由跳轉(zhuǎn)的方式有哪些你知道嗎

    這篇文章主要為大家介紹了vue路由跳轉(zhuǎn)的方式,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2021-11-11
  • VUE實現(xiàn)自身整體組件銷毀的示例代碼

    VUE實現(xiàn)自身整體組件銷毀的示例代碼

    這篇文章主要介紹了VUE實現(xiàn)自身整體組件銷毀的示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Vue百度地圖實現(xiàn)定位和marker拖拽監(jiān)聽功能

    Vue百度地圖實現(xiàn)定位和marker拖拽監(jiān)聽功能

    這篇文章主要介紹了Vue百度地圖實現(xiàn)定位和marker拖拽監(jiān)聽功能,實現(xiàn)思路非常簡單,本文結(jié)合實例代碼效果圖給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-11-11
  • vue?parseHTML函數(shù)解析器遇到結(jié)束標(biāo)簽

    vue?parseHTML函數(shù)解析器遇到結(jié)束標(biāo)簽

    這篇文章主要介紹了vue?parseHTML函數(shù)源碼解析之析器遇到結(jié)束標(biāo)簽的示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • 基于Vue實現(xiàn)timepicker

    基于Vue實現(xiàn)timepicker

    這篇文章主要為大家詳細(xì)介紹了基于Vue實現(xiàn)timepicker效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-04-04

最新評論