vue學(xué)習(xí)記錄之動態(tài)組件淺析
動態(tài)組件
釋義:運行時在組件之間動態(tài)切換的方法。可以將多個條件組件(使用
v-if、v-else-if、v-else切換的組件)簡化為一行代碼
看個例子 一般來講,我們會這樣實現(xiàn)一個tabs的切換
<template>
<div id="app">
<button v-for="item in tabs" :key="item" @click="onClickTabs(item)">{{item}}</button>
<Buy v-if="index==='Buy'"/>
<cutUp v-else-if="index==='cutUp'"/>
<Fried v-else/>
</div>
</template>
<script>
import Buy from "./components/Buy.vue";
import cutUp from "./components/cutUp.vue";
import Fried from "./components/Fried.vue";
export default {
name: "app",
components: {
Buy,
cutUp,
Fried,
},
created() {},
data() {
return {
tabs: ["Buy", "cutUp", "Fried"],
index:'Buy'
};
},
methods: {
onClickTabs(item){
console.log(item,9999);
this.index=item
}
},
};
</script>
<style lang="scss" scoped>
</style>而動態(tài)組件形式則可以寫成
<template>
<div id="app">
<button v-for="item in tabs" :key="item" @click="onClickTabs(item)">{{item}}</button>
<component :is="index"></component>
</div>
</template>
<script>
import Buy from "./components/Buy.vue";
import cutUp from "./components/cutUp.vue";
import Fried from "./components/Fried.vue";
export default {
name: "app",
components: {
Buy,
cutUp,
Fried,
},
created() {},
data() {
return {
tabs: ["Buy", "cutUp", "Fried"],
index:'Buy'
};
},
methods: {
onClickTabs(item){
console.log(item,9999);
this.index=item
}
},
};
</script>
<style lang="scss" scoped>
</style>在以上例子中,
v-if加組件名被components加is替換掉了。至于其他,則沒太多分別。該傳data傳data,該傳狀態(tài)傳狀態(tài)。
補充:動態(tài)調(diào)用組件示例
<div id="app">
<button @click="changeComponent('coma')">coma</button>
<button @click="changeComponent('comb')">comb</button>
<button @click="changeComponent('comc')">comc</button>
<component :is="com_name"></component>
</div>
<script>
var coma = {
template: '<div>aaaa</div>'
}
var comb = {
template: '<div>bbbb</div>'
}
var comc = {
template: '<div>cccc</div>'
}
let vm = new Vue({
el: '#app',
data: {
com_name: 'coma'
},
components: {
coma: coma,
comb: comb,
comc: comc,
},
methods: {
changeComponent: function(name) {
this.com_name = name
}
}
})
</script>
總結(jié)
到此這篇關(guān)于vue學(xué)習(xí)記錄之動態(tài)組件的文章就介紹到這了,更多相關(guān)vue動態(tài)組件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
vue頁面引入three.js實現(xiàn)3d動畫場景操作
這篇文章主要介紹了vue頁面引入three.js實現(xiàn)3d動畫場景操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2020-08-08
vue-cli5.0?webpack?采用?copy-webpack-plugin?打包復(fù)制文件的方法
今天就好好說說vue-cli5.0種使用copy-webpack-plugin插件該如何配置的問題。這里我們安裝的 copy-webpack-plugin 的版本是 ^11.0.0,感興趣的朋友一起看看吧2022-06-06
在?Vue?項目中如何引用?assets?文件夾中的圖片(方式匯總)
Vue中引用assets文件夾中的圖片有多種方式,在.vue文件的模板部分,使用相對路徑或通過@別名引用圖片,在CSS中,通過相對路徑或@別名引用圖片作為背景,在JavaScript中,通過import語句導(dǎo)入圖片資源,并使用v-bind在模板中綁定顯示,這些方法均可有效管理和引用項目中的圖片資源2024-09-09

