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>
效果:
可以看見,不改寫基類的時候,繼承了父類的所有東西,當前的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)文章
淺談在Vue.js中如何實現(xiàn)時間轉(zhuǎn)換指令
這篇文章主要介紹了淺談在Vue.js中如何實現(xiàn)時間轉(zhuǎn)換指令,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-01-01vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開發(fā),路由配置方式
今天小編就為大家分享一篇vue2.0 獲取從http接口中獲取數(shù)據(jù),組件開發(fā),路由配置方式,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2019-11-11vue.js項目 el-input 組件 監(jiān)聽回車鍵實現(xiàn)搜索功能示例
今天小編就為大家分享一篇vue.js項目 el-input 組件 監(jiān)聽回車鍵實現(xiàn)搜索功能示例,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08vue中使用window.open()參數(shù)示例詳解
這篇文章主要介紹了vue中使用window.open()參數(shù)詳解,本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2023-04-04