Vue <component>实现动态组件

举报
SHQ5785 发表于 2023/01/06 10:25:48 2023/01/06
【摘要】 一、前言<component>元素是vue 里面的内置组件。在<component>里面使用 :is,可以实现动态组件的效果。 二、示例解析下面例子创建一个包含多子组件的 vue 实例。vue代码部分:新建 vue 实例 “app”,这个实例的 components 里面,有3个组件,这些组件都有各自的模板。分别是 acomp,bcomp,ccomphtml 代码部分:使用vue 内置组件...

一、前言

<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”
在这里插入图片描述

三、拓展阅读

四、延伸阅读 Vue $refs 基本用法介绍

说明:vm.$refs 获取一个对象,持有已注册过 ref 的所有子组件(或HTML元素)。
使用:在 HTML元素 中,添加ref属性,然后在JS中通过vm.$refs.属性来获取。
注意:如果获取的是一个子组件,那么通过ref就能获取到子组件中的datamethods

示例代码如下:

<div id="app">
    <input type="text" ref="input1"/>
    <button @click="add">添加</button>
</div>
<script>
new Vue({
    el: "#app",
    methods:{
    add:function(){
        this.$refs.input1.value ="22"; //this.$refs.input1  减少获取dom节点的消耗
        }
    }
})
</script>

一般来讲,获取DOM元素,需通过document.querySelector(".input")获取dom节点,然后再获取input1的值。

但是用ref绑定之后,我们就不需要再通过document.querySelector(".input")获取dom节点了,直接在上面的input上绑定input1,然后在$refs里面调用就行。

javascript里面这样调用:this.$refs.input1 , 这样可以减少获取dom节点的消耗。

【版权声明】本文为华为云社区用户原创内容,未经允许不得转载,如需转载请自行联系原作者进行授权。如果您发现本社区中有涉嫌抄袭的内容,欢迎发送邮件进行举报,并提供相关证据,一经查实,本社区将立刻删除涉嫌侵权内容,举报邮箱: cloudbbs@huaweicloud.com
  • 点赞
  • 收藏
  • 关注作者

评论(0

0/1000
抱歉,系统识别当前为高风险访问,暂不支持该操作

全部回复

上滑加载中

设置昵称

在此一键设置昵称,即可参与社区互动!

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。

*长度不超过10个汉字或20个英文字符,设置后3个月内不可修改。