微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Vue进阶二十五:<component>实现动态组件


一、前言

<component>元素是vue 里面的内置组件。

<component>里面使用 :is,可以实现动态组件效果


二、示例解析

下面例子创建一个包含多子组件的 vue 实例。

  1. vue代码部分:新建 vue 实例 “app”,这个实例的 components 里面,有3个组件,这些组件都有各自的模板。分别是 acomp,bcomp,ccomp

  2. html 代码部分:使用vue 内置组件 <component></component>,并使用 “is” 特性(需要通过v-bind 给 “is” 绑定值)。"is" 绑定值传入一个组件名,就会切换到这个组件。

<div id="app">
	 <component :is="whichcomp"></component> 
	 <button @click="choosencomp('a')">a</button>
	 <button @click="choosencomp('b')">b</button>
	 <button @click="choosencomp('c')">c</button>
 </div>

//做一个包含列表组件
//需要给组件创建props--"todos",用于存放组件通过绑定prop --"todo"获取实例中的data数据"todolists"
var app=new Vue({
    el: '#app',
	components:{
		acomp:{
		   template:
				<p>这里是组件A</p>
		},
		bcomp:{
		   template:
				<p>这里是组件B</p>
		},
		ccomp:{
			template:
				<p>这里是组件C</p>
		}},
	data:{whichcomp:""},
	methods:{
	   choosencomp (x) {
	   		this.whichcomp=x+"comp"
	   	}
	  }
})

网页渲染效果
点击 A 按钮,文字显示切换到 “显示组件A”

在这里插入图片描述


点击C 按钮,文字显示切换到 “显示组件C”

在这里插入图片描述

三、拓展阅读

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐