Vue非單文件組件使用詳解
傳統(tǒng)網(wǎng)頁一些不可避免的小問題:
1.網(wǎng)頁JS、CSS等資源依賴關(guān)系混亂,不方便維護
2.代碼復(fù)用率很低
使用組件將代碼進行復(fù)用,簡化項目結(jié)構(gòu),提高運行效率,便于維護
組件定義
組件即為實現(xiàn)應(yīng)用中局部功能代碼(css、html、js)和資源(mp3、mp4、字體資源)的集合
模塊化:當(dāng)應(yīng)用中的JS都是以模塊來編寫的,那這個應(yīng)用就是一個模塊化的應(yīng)用
組件化:當(dāng)應(yīng)用中的JS都是以組件來編寫的,那這個應(yīng)用就是一個組件化的應(yīng)用
傳統(tǒng)網(wǎng)頁
傳統(tǒng)網(wǎng)站如需要新建一個頁面,需要頭部、中間內(nèi)容部分、底部,每次新建頁面都得復(fù)制來一套,引用的外部樣式也是如此;如果有一處需要更改,那么所復(fù)制的每個頁面都需要更改,還有著遺漏某個隱藏極深的頁面漏改的可能。

組件
組件是獨立和可復(fù)用的代碼組織單元,組件系統(tǒng)是vue核心特性之一,它讓開發(fā)者使用小型、獨立和通常可復(fù)用的組件構(gòu)建大型應(yīng)用,使得前端開發(fā)的過程變成搭積木的過程。

傳統(tǒng)代碼
實現(xiàn)步驟
新建一個頁面并創(chuàng)建好頁面容器及對應(yīng)的Vue實例,在data中定義三個變量如下

data: function () {
return {
header:'頁面頭部',
content: '頁面內(nèi)容',
footer:'頁面底部'
};
},在頁面中通過差值語法的方式將數(shù)據(jù)渲染展示

<div class="box">{{header}}</div>
<hr />
<div class="box">{{content}}</div>
<hr />
<div class="box">{{footer}}</div>
這樣看上去也沒有什么問題,影響貌似也不大,但是如果現(xiàn)在讓你再實現(xiàn)一個頁面,保持結(jié)構(gòu)不變的同時修改數(shù)據(jù),那是不是只能把這段代碼復(fù)制粘貼呢?這樣就違背了組件的作用,組件是把代碼進行復(fù)用而不是復(fù)制
組件代碼
定義組件
使用Vue.extend(option)創(chuàng)建,格式與new Vue時幾乎一樣,但是這里有兩點要注意;
一是不需要寫el,因為el最終是由vm來決定的、二是data必須寫成函數(shù),這樣組件復(fù)用時互不干擾

通過template字段直接將html編寫在里面即可
const header = Vue.extend({
template:`
<div>
<span>{{header}}</span>
</div>
`,
data(){
return {
header:'頁面頭部'
}
}
});注冊組件
局部注冊
在new Vue中使用components選項即可實現(xiàn)組件局部注冊

// 創(chuàng)建vue實例
const vm = new Vue({
el: '#root',
//2.組件注冊
components:{
headercom:header,
contentcom:content,
footercom:footer,
}
});使用局部注冊時,如果頁面上有兩個容器對應(yīng)著兩個vm,那只有注冊過的vm才能使用這個組件,如果另外一個vm需要使用也需要再次注冊才能使用,但是這樣代碼又重復(fù)了,所以有了下面的全局注冊

全局注冊
全局注冊方法:使用Vue.component(‘’,‘’),它有兩個參數(shù),第一個是組件名,第二個組件的指向,也就是你定義好的組件

Vue.component('name',name);使用組件
定義跟注冊好組件后即可在頁面進行使用,通過編寫組件標(biāo)簽的形式即可


<headercom></headercom> <hr /> <contentcom></contentcom> <hr /> <footercom></footercom>
避坑
1.組件注冊時使用大小寫命名會報錯,同時組件名稱不要使用一些html標(biāo)簽名稱
2.components注冊時單詞拼寫容易錯誤
3.單個vm中存在多個components
總結(jié)
到此這篇關(guān)于Vue非單文件組件使用的文章就介紹到這了,更多相關(guān)Vue非單文件組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue.js實現(xiàn)大屏數(shù)字滾動翻轉(zhuǎn)效果
大屏數(shù)字滾動翻轉(zhuǎn)效果來源于最近工作中element后臺管理頁面一張大屏的UI圖,該UI圖上有一個模塊需要有數(shù)字往上翻動的效果。本文通過截圖代碼的形式給大家介紹Vue.js實現(xiàn)大屏數(shù)字滾動翻轉(zhuǎn)效果,感興趣的朋友一起看看吧2019-11-11
element-ui實現(xiàn)表格邊框的動態(tài)切換并防抖
這篇文章主要介紹了element-ui實現(xiàn)表格邊框的動態(tài)切換并防抖方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-08-08
vue3點擊出現(xiàn)彈窗后背景變暗且不可操作的實現(xiàn)代碼
這篇文章主要介紹了vue3點擊出現(xiàn)彈窗后背景變暗且不可操作的實現(xiàn)代碼,本文通過實例代碼圖文相結(jié)合給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-08-08

