Vue全局注冊與局部注冊兩種組件注冊的方式
一、組件注冊的方式
在Vue中組件的注冊一般可以分為兩種方式,你可以在main.ts或globalComponents.ts等統(tǒng)一管理文件中對公共組件進(jìn)行注冊。也可以在父組件中引入組件并在components屬性中對組件進(jìn)行按需注冊(OptionsAPI),這樣便可以在template標(biāo)簽中直接使用。
1. 全局注冊
全局組件的好處便是在組件內(nèi)部不需要導(dǎo)入文件并進(jìn)行局部注冊,便可以直接在template上直接使用該子組件。全局注冊一般是用于注冊公共組件(在一個(gè)組件庫/多個(gè)組件內(nèi)部都會使用到的組件)。
全局注冊需要使用到Vue應(yīng)用實(shí)例上的component方法來進(jìn)行注冊,在聊component用法之前,我們可以簡單認(rèn)識一下Vue應(yīng)用實(shí)例上有哪些方法?(應(yīng)用實(shí)例指的是new Vue得到的對象或createApp得到的對象)具體的可以參照「Application Api官方文檔」。我們用的較多的便是其中的mount、use方法,一個(gè)是用于掛載DOM真實(shí)對象,一個(gè)用于安裝相關(guān)的插件。
其次便是我們要聊到的全局組件注冊的方法component了。方法接收兩個(gè)參數(shù),分別是組件名稱與組件本身,以下為Vue官方給出的component方法的TypeScript注解:
interface App {
component(name: string): Component | undefined
component(name: string, component: Component): this
}Component本質(zhì)上是一個(gè)對象,在Vue項(xiàng)目中我們雖然使用的是單文件的.vue文件來構(gòu)建一個(gè)組件,但經(jīng)過vue-loader的解析之后得到的其實(shí)就是一個(gè)對象,通過打印main.ts中引入的App.vue我們可以得到以下結(jié)果,可以很明顯的看出Component本質(zhì)就是一個(gè)對象。

接著我們來聊聊要怎么使用component方法進(jìn)行公共組件的全局注冊,只需要將組件的命名填入以及對應(yīng)的組件對象傳入即可完成注冊。這里的命名推薦使用Kebab-Case與Pascal-Case也就是中橫線命名法與大駝峰命名法,原因是避免與HTML的保留標(biāo)簽沖突而導(dǎo)致一些意料之外的沖突。
這里比較有意思的點(diǎn)是,在component方法中以Pascal-Case命名,則在模板中使用該字符時(shí)既可以用Kebab-Case也可以使用Pascal-Case,而使用中橫線命名法Kebab-Case注冊,則模板中只能使用Kebab-Case形式來使用。
import { createApp } from "vue";
import App from "./App.vue";
import MyComponent from "./components/MyComponent.vue";
const app = createApp(App);
// 使用Pascal-Case命名規(guī)則, 在template標(biāo)簽中可以使用 MyComponent 也可以使用 my-component?
app.component("MyComponent", MyComponent);
// 使用Kebab-Case命名規(guī)則, 在template標(biāo)簽中只能使用 my-component 而不能使用 MyComponent
app.component("my-component", MyComponent);
app.mount("#app");以上便是對于全局注冊所要分享的知識點(diǎn),接下來讓我們再聊聊局部注冊。
2. 局部注冊
局部注冊的使用場景相較于全局注冊就廣多了,因?yàn)橐话愣晕覀兏枰氖前葱杓虞d,而不是在項(xiàng)目啟動時(shí)就將所有需要的組件進(jìn)行注冊,這將消耗較多的性能。
局部注冊需要在父組件引入所需要使用到的子組件,并且在父組件實(shí)例中的components屬性中對子組件進(jìn)行注冊(使用OptionsAPI的情況下),在使用Composition API的情況下,只需要在script setup中將所需的組件引入就可以在template中直接使用。
對于標(biāo)簽的命名與使用與全局組件注冊的特性一致。
<!-- Options API ?-->
<template>
? <my-component></my-component>
</template>
<script>
import MyComponent from './components/MyComponent.vue'
export default {
? name: 'App',
? components: {
? ? // 自定義組件標(biāo)簽名: 組件實(shí)例
? ? MyComponent
? }
}
</script>
<!-- Composition API -->
<template>
? <my-component></my-component>
</template>
<script setup>
import MyComponent from './components/MyComponent.vue';
</script>到此這篇關(guān)于Vue全局注冊與局部注冊兩種組件注冊的方式的文章就介紹到這了,更多相關(guān)Vue全局注冊與局部注冊內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue定時(shí)器清除不掉,導(dǎo)致功能頻繁執(zhí)行問題
這篇文章主要介紹了vue定時(shí)器清除不掉,導(dǎo)致功能頻繁執(zhí)行問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
vue.js樣式布局Flutter業(yè)務(wù)開發(fā)常用技巧
這篇文章主要為大家介紹了vue.js樣式布局Flutter業(yè)務(wù)開發(fā)中的常用技巧,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪2021-11-11
vue中關(guān)于v-for循環(huán)key值問題的研究
這篇文章主要介紹了vue中關(guān)于v-for循環(huán)key值問題的研究,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-06-06
前端實(shí)現(xiàn)簡單的sse封裝方式(React hook Vue3)
這篇文章主要介紹了前端實(shí)現(xiàn)簡單的sse封裝方式(React hook Vue3),具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
Vue3+Vite項(xiàng)目中引入pinia和pinia-plugin-persistedstate的方法代碼
這篇文章主要給大家介紹了關(guān)于Vue3+Vite項(xiàng)目中引入pinia和pinia-plugin-persistedstate的相關(guān)資料,Pinia是Vue.js的官方狀態(tài)管理庫,輕量且功能強(qiáng)大,支持模塊化和TypeScript,PiniaPluginPersistedState是一個(gè)插件,需要的朋友可以參考下2024-11-11
Vue動態(tài)設(shè)置圖片時(shí)src不生效的原因及解決方法
這篇文章主要介紹了Vue動態(tài)設(shè)置圖片時(shí)src不生效的原因及解決方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2022-08-08
vue3前端實(shí)現(xiàn)全屏顯示及元素垂直填滿頁面效果
這篇文章主要給大家介紹了關(guān)于vue3前端實(shí)現(xiàn)全屏顯示及元素垂直填滿頁面效果的相關(guān)資料,文中還給大家介紹了vue3實(shí)現(xiàn)某一個(gè)元素全屏之后就黑屏了的解決辦法,需要的朋友可以參考下2024-02-02
Vue 項(xiàng)目部署到服務(wù)器的問題解決方法
本篇文章主要介紹了Vue 項(xiàng)目部署到服務(wù)器的問題解決方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-12-12

