首页 > 其他分享 >Vue进阶(二十五):<component>实现动态组件

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

时间:2023-03-23 10:33:01浏览次数:47  
标签:Vue 进阶 refs 绑定 component input1 获取 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" 在这里插入图片描述

三、拓展阅读

四、延伸阅读

说明: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节点的消耗。

标签:Vue,进阶,refs,绑定,component,input1,获取,vue,组件
From: https://blog.51cto.com/shq5785/6144452

相关文章

  • 在基于vue-next-admin的Vue3+TypeScript前端项目中,为了使用方便全局挂载的对象接口
    在基于vue-next-admin 的Vue3+TypeScript前端项目中,可以整合自己的.NET后端,前端操作一些功能的时候,为了使用方便全局挂载的对象接口,以便能够快速处理一些特殊的操作,如......
  • 爬虫进阶之多线程爬虫问题详解
    大多数正常人在下载图片的时候都是一个一个点击保存,图片越多花费的时间越多,大大的降低了工作效率。如果是学了爬虫的,一定会想到多线程来自动下载保存图片。多线程介绍:多......
  • vue学习笔记01
    vue3带来的变化vue3的发布时间2020/09/19。优点:更好的性能、更小的包体积、更好的TypeScript集成、更优秀的API设计。optionsAPI->CompositionAPI,由选项API......
  • Vue.js 具名插槽
    视频componentsCategray.vue<template> <divclass="category"> <h3>{{title}}分类</h3> <!--定义一个插槽(挖个坑,等着组件的使用者进行填充)--> <slotname="ce......
  • Vue.js 默认插槽
    默认插槽视频componentsCategray.vue<template> <divclass="category"> <h3>{{title}}分类</h3> <!--定义一个插槽(挖个坑,等着组件的使用者进行填充)--> <slot>......
  • Vue3学习笔记 —— 状态管理、Vuex、Pinia (未完结)
    优秀文章分享:vue中使用vuex(超详细)-掘金(juejin.cn)一、状态管理1.1、什么是状态管理?理论上来说,每一个Vue组件实例都已经在“管理”它自己的响应式状态了。我们以......
  • vue中设置input输入框的值为正整数,不能为负数和小数
    importVuefrom'vue'Vue.directive('Int',{bind:function(el){constinput=el.getElementsByTagName('input')[0]input.onkeyup=function(e){......
  • vue中van-picker的选项插槽使用方法
    van-picker的内部选项怎么来自定义首先要确保 VantUI 的版本在2.10.0以上然后利用插槽slot来实现,在Vant里插槽有一个进阶用法 #<van-picker:show-toolbar="fal......
  • vue+element-ui+springboot实现修改当前登录用户的信息
    正文:话不多说,直接上代码springboot代码/***根据id修改当前登录用户的信息**@paramusername*@return*/@GetMapping("/userna......
  • spring @component的作用
    1、@controller控制器(注入服务)2、@service服务(注入dao)3、@repositorydao(实现dao访问)4、@component(把普通pojo实例化到spring容器中,相当于配置文件中的<beanid=""cl......