Vue組件的繼承用法示例詳解
Vue組件的繼承用法
vue組件的繼承適用于UI幾乎一樣,只是數(shù)據(jù)不一樣的情況下,但是這種情況通過統(tǒng)一封裝組件也是能實現(xiàn)的,小功能建議用封裝,大功能建議用組件繼承,因為大功能在結(jié)合搜參數(shù)的需要多重的判斷,這樣會導(dǎo)致封裝的組件比較繁雜,出現(xiàn)過多的判斷,用繼承可以改寫基類中的方法和數(shù)據(jù)
基類案例:
<template>
<div class="hello">
父類:{{name}}
<span>{{title}}</span>
</div>
</template>
<script>
export default {
name: 'HelloWorld',
data(){
return{
name:'末晨曦吖',
title:'Vue組件的繼承用法'
}
},
mounted(){
console.log('父組件',this.name);
},
methods:{
handle(){
console.log('我是父組件方法');
}
}
}
</script>
<style scoped>
</style>繼承基類案例:
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
name: 'App',
extends:HelloWorld,
data(){
return {
}
},
mounted() {
console.log("子類繼承父組件name", this.name);
this.handle()
// this.title = '子組件更改了title'
},
components:{
},
methods:{
}
}
</script>
<style scoped>
</style>效果:

可以看見,不改寫基類的時候,繼承了父類的所有東西,當(dāng)前的data,dom,方法都繼承了
改寫父類案例:
<template>
<div id="app">
子組件:{{name}}
<span>{{title}}</span>
</div>
</template>
<script>
import HelloWorld from './components/HelloWorld.vue'
export default {
name: 'App',
extends:HelloWorld,
data(){
return {
}
},
mounted() {
console.log("子類繼承父組件name", this.name);
this.handle()
this.name = '子組件更改了name'
this.title = '子組件更改了title'
},
components:{
},
methods:{
handle(){
console.log('子組件改寫方法');
}
}
}
</script>
<style scoped>
</style>
效果:

我們會發(fā)現(xiàn),改寫后基類的值也被覆寫了,方法也被覆寫了,html模板也完全被改寫了
HTML模板要么完全繼承,要么完全重寫,不能按需繼承某個部分。如果子類在結(jié)構(gòu)上跟基類有所差異,還是需要在基類中做條件判斷。如果模板差異太大,可以重新定義子類自己的template,至少還可以重用一部分業(yè)務(wù)邏輯代碼。
到此這篇關(guān)于Vue組件的繼承用法的文章就介紹到這了,更多相關(guān)Vue組件繼承用法內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談element中InfiniteScroll按需引入的一點注意事項
這篇文章主要介紹了淺談element中InfiniteScroll按需引入的一點注意事項,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2020-06-06
使用vue自定義指令開發(fā)表單驗證插件validate.js
今天就來介紹一下如何利用vue的自定義指令directive來開發(fā)一個表單驗證插件的過程,需要的朋友可以參考下2019-05-05
詳解如何將 Vue-cli 改造成支持多頁面的 history 模式
本篇文章主要介紹了詳解如何將 Vue-cli 改造成支持多頁面的 history 模式,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-11-11

