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

詳解Vue的組件注冊(cè)

 更新時(shí)間:2023年05月05日 11:00:30   作者:自xing且樂(lè)觀~  
組件是Vue.js最強(qiáng)大的功能之一。組件可以擴(kuò)展HTML元素,封裝可重用的代碼。在較高層面上,組件是自定義元素,Vue.js 的編譯器為它添加特殊功能,需要的朋友可以參考下

引言

一個(gè) Vue 組件在使用前需要先被“注冊(cè)”,這樣 Vue 才能在渲染模板時(shí)找到其對(duì)應(yīng)的實(shí)現(xiàn)。

組件注冊(cè)有兩種方式:全局注冊(cè)和局部注冊(cè)。

全局注冊(cè)?

我們可以使用 Vue 應(yīng)用實(shí)例的 app.component() 方法,讓組件在當(dāng)前 Vue 應(yīng)用中全局可用。

import { createApp } from 'vue'
const app = createApp({})
app.component(
  // 注冊(cè)的名字
  'MyComponent',
  // 組件的實(shí)現(xiàn)
  {
    /* ... */
  }
)

如果使用單文件組件,你可以注冊(cè)被導(dǎo)入的 .vue 文件:

import MyComponent from './App.vue'
app.component('MyComponent', MyComponent)

app.component() 方法可以被鏈?zhǔn)秸{(diào)用:

app
  .component('ComponentA', ComponentA)
  .component('ComponentB', ComponentB)
  .component('ComponentC', ComponentC)

全局注冊(cè)的組件可以在此應(yīng)用的任意組件的模板中使用:

<!-- 這在當(dāng)前應(yīng)用的任意組件中都可用 -->
<ComponentA/>
<ComponentB/>
<ComponentC/>

所有的子組件也可以使用全局注冊(cè)的組件,這意味著這三個(gè)組件也都可以在彼此內(nèi)部使用。

局部注冊(cè)?

全局注冊(cè)雖然很方便,但有以下幾個(gè)問(wèn)題:

  1. 全局注冊(cè),但并沒(méi)有被使用的組件無(wú)法在生產(chǎn)打包時(shí)被自動(dòng)移除 (也叫“tree-shaking”)。如果你全局注冊(cè)了一個(gè)組件,即使它并沒(méi)有被實(shí)際使用,它仍然會(huì)出現(xiàn)在打包后的 JS 文件中。
  2. 全局注冊(cè)在大型項(xiàng)目中使項(xiàng)目的依賴關(guān)系變得不那么明確。在父組件中使用子組件時(shí),不太容易定位子組件的實(shí)現(xiàn)。和使用過(guò)多的全局變量一樣,這可能會(huì)影響應(yīng)用長(zhǎng)期的可維護(hù)性。

相比之下,局部注冊(cè)的組件需要在使用它的父組件中顯式導(dǎo)入,并且只能在該父組件中使用。它的優(yōu)點(diǎn)是使組件之間的依賴關(guān)系更加明確,并且對(duì) tree-shaking 更加友好。

局部注冊(cè)需要使用 components 選項(xiàng):

<script>
import ComponentA from './ComponentA.vue'
export default {
  components: {
    ComponentA
  }
}
</script>
<template>
  <ComponentA />
</template>

對(duì)于每個(gè) components 對(duì)象里的屬性,它們的 key 名就是注冊(cè)的組件名,而值就是相應(yīng)組件的實(shí)現(xiàn)。上面的例子中使用的是 ES2015 的縮寫語(yǔ)法,等價(jià)于:

export default {
  components: {
    ComponentA: ComponentA
  }
  // ...
}

請(qǐng)注意:局部注冊(cè)的組件在后代組件中并不可用。在這個(gè)例子中,ComponentA 注冊(cè)后僅在當(dāng)前組件可用,而在任何的子組件或更深層的子組件中都不可用。

組件名格式?

在整個(gè)指引中,我們都使用 PascalCase 作為組件名的注冊(cè)格式,這是因?yàn)椋?/p>

  1. PascalCase 是合法的 JavaScript 標(biāo)識(shí)符。這使得在 JavaScript 中導(dǎo)入和注冊(cè)組件都很容易,同時(shí) IDE 也能提供較好的自動(dòng)補(bǔ)全。
  2. <PascalCase /> 在模板中更明顯地表明了這是一個(gè) Vue 組件,而不是原生 HTML 元素。同時(shí)也能夠?qū)?Vue 組件和自定義元素 (web components) 區(qū)分開(kāi)來(lái)。

在單文件組件和內(nèi)聯(lián)字符串模板中,我們都推薦這樣做。但是,PascalCase 的標(biāo)簽名在 DOM 模板中是不可用的。

為了方便,Vue 支持將模板中使用 kebab-case 的標(biāo)簽解析為使用 PascalCase 注冊(cè)的組件。這意味著一個(gè)以 MyComponent 為名注冊(cè)的組件,在模板中可以通過(guò) <MyComponent> 或 <my-component> 引用。這讓我們能夠使用同樣的 JavaScript 組件注冊(cè)代碼來(lái)配合不同來(lái)源的模板。

到此這篇關(guān)于詳解Vue的組件注冊(cè)的文章就介紹到這了,更多相關(guān)Vue組件注冊(cè)內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • vuex根據(jù)不同的用戶權(quán)限展示不同的路由列表功能

    vuex根據(jù)不同的用戶權(quán)限展示不同的路由列表功能

    最近接到一個(gè)新的需求,要求將系統(tǒng)的用戶進(jìn)行分類,用戶登陸后根據(jù)不同的用戶權(quán)限展示不同的功能列表。這篇文章主要介紹了vuex根據(jù)不同的用戶權(quán)限展示不同的路由列表,需要的朋友可以參考下
    2019-09-09
  • Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法

    這篇文章主要介紹了Vue-CLI 3.X 部署項(xiàng)目至生產(chǎn)服務(wù)器的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 詳解jenkins自動(dòng)化部署vue

    詳解jenkins自動(dòng)化部署vue

    這篇文章主要介紹了jenkins自動(dòng)化部署vue,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05
  • 解決webpack+Vue引入iView找不到字體文件的問(wèn)題

    解決webpack+Vue引入iView找不到字體文件的問(wèn)題

    今天小編就為大家分享一篇解決webpack+Vue引入iView找不到字體文件的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2018-09-09
  • 何時(shí)/使用 Vue3 render 函數(shù)的教程詳解

    何時(shí)/使用 Vue3 render 函數(shù)的教程詳解

    這篇文章主要介紹了何時(shí)/使用 Vue3 render 函數(shù)的教程詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • vue 中的keep-alive實(shí)例代碼

    vue 中的keep-alive實(shí)例代碼

    這篇文章主要介紹了vue中的keep-alive實(shí)例代碼,vue實(shí)現(xiàn)組件信息緩存的方法,在文中也給大家提到,需要的朋友可以參考下
    2018-07-07
  • vue3彈出層V3Popup實(shí)例詳解

    vue3彈出層V3Popup實(shí)例詳解

    這篇文章主要介紹了vue3彈出層V3Popup實(shí)例詳解,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • vue 單元測(cè)試的推薦插件和使用示例

    vue 單元測(cè)試的推薦插件和使用示例

    單元測(cè)試是軟件開(kāi)發(fā)非?;A(chǔ)的一部分。單元測(cè)試會(huì)封閉執(zhí)行最小化單元的代碼,使得添加新功能和追蹤問(wèn)題更容易。Vue 的單文件組件使得為組件撰寫隔離的單元測(cè)試這件事更加直接。它會(huì)讓你更有信心地開(kāi)發(fā)新特性而不破壞現(xiàn)有的實(shí)現(xiàn),并幫助其他開(kāi)發(fā)者理解你的組件的作用。
    2021-06-06
  • Vue使用konva實(shí)現(xiàn)一個(gè)簡(jiǎn)便的流程圖

    Vue使用konva實(shí)現(xiàn)一個(gè)簡(jiǎn)便的流程圖

    日常開(kāi)發(fā)中我們可能碰到流程圖的需求,實(shí)現(xiàn)流程圖的庫(kù)有很多,如果我們想要實(shí)現(xiàn)一個(gè)簡(jiǎn)便的流程圖可以使用konva庫(kù)來(lái)實(shí)現(xiàn),下面我們就來(lái)看一下具體的實(shí)現(xiàn)過(guò)程,需要的朋友可以參考下
    2023-08-08
  • Vant主題定制如何修改顏色樣式

    Vant主題定制如何修改顏色樣式

    這篇文章主要介紹了Vant主題定制如何修改顏色樣式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-04-04

最新評(píng)論