Vue組件的繼承用法示例詳解
Vue組件的繼承用法
vue組件的繼承適用于UI幾乎一樣,只是數(shù)據(jù)不一樣的情況下,但是這種情況通過(guò)統(tǒng)一封裝組件也是能實(shí)現(xiàn)的,小功能建議用封裝,大功能建議用組件繼承,因?yàn)榇蠊δ茉诮Y(jié)合搜參數(shù)的需要多重的判斷,這樣會(huì)導(dǎo)致封裝的組件比較繁雜,出現(xiàn)過(guò)多的判斷,用繼承可以改寫(xiě)基類(lèi)中的方法和數(shù)據(jù)
基類(lèi)案例:
<template> <div class="hello"> 父類(lèi):{{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>
繼承基類(lèi)案例:
<script> import HelloWorld from './components/HelloWorld.vue' export default { name: 'App', extends:HelloWorld, data(){ return { } }, mounted() { console.log("子類(lèi)繼承父組件name", this.name); this.handle() // this.title = '子組件更改了title' }, components:{ }, methods:{ } } </script> <style scoped> </style>
效果:
可以看見(jiàn),不改寫(xiě)基類(lèi)的時(shí)候,繼承了父類(lèi)的所有東西,當(dāng)前的data,dom,方法都繼承了
改寫(xiě)父類(lèi)案例:
<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("子類(lèi)繼承父組件name", this.name); this.handle() this.name = '子組件更改了name' this.title = '子組件更改了title' }, components:{ }, methods:{ handle(){ console.log('子組件改寫(xiě)方法'); } } } </script> <style scoped> </style>
效果:
我們會(huì)發(fā)現(xiàn),改寫(xiě)后基類(lèi)的值也被覆寫(xiě)了,方法也被覆寫(xiě)了,html模板也完全被改寫(xiě)了
HTML模板要么完全繼承,要么完全重寫(xiě),不能按需繼承某個(gè)部分。如果子類(lèi)在結(jié)構(gòu)上跟基類(lèi)有所差異,還是需要在基類(lèi)中做條件判斷。如果模板差異太大,可以重新定義子類(lèi)自己的template,至少還可以重用一部分業(yè)務(wù)邏輯代碼。
到此這篇關(guān)于Vue組件的繼承用法的文章就介紹到這了,更多相關(guān)Vue組件繼承用法內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
淺談在Vue.js中如何實(shí)現(xiàn)時(shí)間轉(zhuǎn)換指令
這篇文章主要介紹了淺談在Vue.js中如何實(shí)現(xiàn)時(shí)間轉(zhuǎn)換指令,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2019-01-01Vue組件簡(jiǎn)易模擬實(shí)現(xiàn)購(gòu)物車(chē)
這篇文章主要為大家詳細(xì)介紹了Vue組件簡(jiǎn)易模擬實(shí)現(xiàn)購(gòu)物車(chē),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2020-12-12vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開(kāi)發(fā),路由配置方式
今天小編就為大家分享一篇vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開(kāi)發(fā),路由配置方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-11-11vue.js項(xiàng)目 el-input 組件 監(jiān)聽(tīng)回車(chē)鍵實(shí)現(xiàn)搜索功能示例
今天小編就為大家分享一篇vue.js項(xiàng)目 el-input 組件 監(jiān)聽(tīng)回車(chē)鍵實(shí)現(xiàn)搜索功能示例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2018-08-08vue中使用window.open()參數(shù)示例詳解
這篇文章主要介紹了vue中使用window.open()參數(shù)詳解,本文通過(guò)示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2023-04-04