MM131美女爱做视频在线看_性强烈的欧美三级视频_男女性潮高清免费网站_日日摸日日碰夜夜爽歪歪

IT培訓(xùn)-高端面授IT培訓(xùn)機(jī)構(gòu)
云和教育:云和數(shù)據(jù)集團(tuán)高端IT職業(yè)教育品牌
  • 國(guó)家級(jí)
    全民數(shù)字素養(yǎng)與技能培訓(xùn)基地
  • 河南省
    第一批產(chǎn)教融合型企業(yè)建設(shè)培育單位
  • 鄭州市
    數(shù)字技能人才(碼農(nóng))培養(yǎng)評(píng)價(jià)聯(lián)盟

VUE中怎樣注冊(cè)組件?

  • 發(fā)布時(shí)間:
    2022-10-08
  • 版權(quán)所有:
    云和教育
  • 分享:

 

vue 是一個(gè)完全支持組件化開(kāi)發(fā)的框架, 組件之間可以進(jìn)行相互的引用。vue 中組件的引用原則:先注冊(cè)后使用。

1. 組件的注冊(cè)

組件之間可以進(jìn)行相互的引用,例如:

注冊(cè)組件的的方式:分為“全局注冊(cè)”和“局部注冊(cè)”兩種,其中:

  • 被全局注冊(cè)的組件,可以在全局任何一個(gè)組件內(nèi)使用
  • 被局部注冊(cè)的組件,只能在當(dāng)前注冊(cè)的范圍內(nèi)使用

1)全局注冊(cè)組件

<dependency>
<groupId>org.springframework.boot</groupId> <artifactId>spring-boot-starter-actuator</artifactId>
 import { createApp } from 'vue'
 import App from './App.vue'
 // 1.導(dǎo)入 Swiper 和 Test 兩個(gè)組件
 import Swiper from './components/MySwiper.vue'
 import Test from './components/MyTest.vue'

 const app = createApp(App)

// 2.調(diào)用app實(shí)例的component()方法,在全局注冊(cè)my-swiper和my-test兩個(gè)組件
 app.component('my-swiper', Swiper)
 app.component('my-test', Test)

 app.mount('#app')

2)使用全局注冊(cè)組件

使用app.component() 方法注冊(cè)的全局組件,直接以標(biāo)簽的形式進(jìn)行使用即可,例如:

 

 //在 main.js中,注冊(cè)了my-swiper 和my-test兩個(gè)全局組件
 spa_app.component('my-swiper', Swiper)
 spa_app.component('my-test', Test)

 <!--在其他組件中,直接以標(biāo)簽的形式,使用剛才注冊(cè)的全局組件即可
 <template>
 <h1>這是App根組件</h1>
 <hr/>
 <my-swiper></my-swiper>

<my-test></my-test>
 </template>

3)局部注冊(cè)組件

<template>
 <h1>這是App根組件</h1>

<my-swiper></my-swiper>

<my-search></my-search>

 </template>

 <script>
 import Search from './components/MySearch.vue'
 export default {
components:{// 通過(guò) components節(jié)點(diǎn),為當(dāng)前的組件注冊(cè)私有子組件

'my-search': Search,


 },
}
 </script>

2.全局注冊(cè)和局部注冊(cè)的區(qū)別

  • 被全局注冊(cè)的組件,可以在全局任何一個(gè)組件內(nèi)使用
  • 被局部注冊(cè)的組件,只能在當(dāng)前注冊(cè)的范圍內(nèi)使用

應(yīng)用場(chǎng)景: 如果某些組件在開(kāi)發(fā)期間的使用頻率很高,推薦進(jìn)行全局注冊(cè);

如果某些組件只在特定的情況下會(huì)被用到,推薦進(jìn)行局部注冊(cè)。

3.組件注冊(cè)時(shí)名稱(chēng)的大小寫(xiě)

在進(jìn)行組件的注冊(cè)時(shí),定義組件注冊(cè)名稱(chēng)的方式有兩種:

①使用kebab-case命名法(俗稱(chēng)短橫線命名法,例如my-swiper 和my-search)

②使用PascalCase命名法(俗稱(chēng)帕斯卡命名法或大駝峰命名法,例如MySwiper和MySearch)

短橫線命名法的特點(diǎn):

必須嚴(yán)格按照短橫線名稱(chēng)進(jìn)行使用

帕斯卡命名法的特點(diǎn):

既可以嚴(yán)格按照帕斯卡名稱(chēng)進(jìn)行使用,又可以轉(zhuǎn)化為短橫線名稱(chēng)進(jìn)行使用

注意:在實(shí)際開(kāi)發(fā)中,推薦使用帕斯卡命名法為組件注冊(cè)名稱(chēng),因?yàn)樗倪m用性更強(qiáng)。

4.通過(guò)name 屬性注冊(cè)組件

在注冊(cè)組件期間,除了可以直接提供組件的注冊(cè)名稱(chēng)之外,還可以把組件的name 屬性作為注冊(cè)后組件的名稱(chēng),

示例代碼如下:

5.組件之間的樣式?jīng)_突問(wèn)題

默認(rèn)情況下,寫(xiě)在.vue 組件中的樣式會(huì)全局生效,因此很容易造成多個(gè)組件之間的樣式?jīng)_突問(wèn)題。導(dǎo)致組件之間樣式?jīng)_突的根本原因是:

單頁(yè)面應(yīng)用程序中,所有組件的DOM 結(jié)構(gòu),都是基于唯一的index.html 頁(yè)面進(jìn)行呈現(xiàn)的

每個(gè)組件中的樣式,都會(huì)影響整個(gè)index.html 頁(yè)面中的DOM 元素