Vue的ref引用及插槽

ref引用

ref被用来给元素或子组件注册引用信息。引用信息将会注册在父组件的$refs对象上。如果在普通的DOM元素上使用,引用指向的就是DOM元素;如果用在子组件上,引用就指向组件实例。(可用于访问子组件实例或子元素

<p ref='p'>hello</p>

<child-component ref='child'></child-component>

当v-for用于元素或组件的时候,引用的信息将是包含DOM节点或组件实例的数组。

注意:因为ref本身是作为渲染结果被创建的,在初始渲染的时候你还不能访问它们,因为它们还不存在。

ref引用DOM元素

引用ref引用页面上的DOM元素:
在这里插入图片描述
点击按钮后效果如图:
在这里插入图片描述

ref引用组件实例

要使用 ref 引用页面上的组件实例:父组件访问子组件实例

RefCom1组件:
在这里插入图片描述子组件RefCom2:
在这里插入图片描述
实现效果:
在这里插入图片描述

实现标签的按需切换

通过布尔值 inputVisible 来控制组件中的文本框与按钮的按需切换,希望文本框显示出来后立即获得焦点。

补充: this.$nextTick(cb)方法

组件的$nextTick(callback)方法,会把callback回调函数推迟到下一个DOM更新周期之后执行。通俗讲,就是等组件的DOM异步地重新渲染完成后,再执行callback回调函数,从而能保证callback回调函数可以操作到最新的DOM元素。

在这里插入图片描述
在这里插入图片描述

插槽

编译作用域:父组件模板的所有东西都会在父级作用域内编译,子组件模板的所有东西都会在子级作用域内编译。

插槽(slot):是vue为组件的封装者提供的能力。允许在封装组件时,把不确定的,希望由用户指定的部分定义为插槽。插槽将父组件的内容与子组件的模板相混合,从而弥补了视图的不足。

如果父组件没有插入内容,那么slot的内容就作为默认出现;若父组件插入了内容,则slot的内容将被插入的内容替换掉。

匿名插槽

在封装组件时,可以通过<slot>元素定义插槽,从而为用户与理由内容占位符。匿名插槽(默认插槽),有且只有一个。

例如:

子组件:
在这里插入图片描述
父组件:
在这里插入图片描述
补充:
(1)如果在封装组件时没有预留任何<slot>插槽,则用户提供的内容都会被丢弃。

(2)后备内容:如果没有为插槽提供内容,那么后备内容会生效。
在这里插入图片描述

具名插槽

如果在封装组件时需要预留多个插槽节点,则需要为每个 <slot> 插槽指定具体的 name 名称。这种带有具体名称的插槽叫做“具名插槽”。

例如:

SlotSon组件:
在这里插入图片描述

SlotFather组件:
在这里插入图片描述
在这里插入图片描述

作用域插槽

在封装组件的过程中,可以为预留的<slot>插槽绑定props数据,这种带有props数据的<slot>叫做“作用域插槽”。

例如:

SlotSon2组件:(通过插槽给父组件传递数据)
在这里插入图片描述
SlotFather组件:接收插槽传过来的数据,赋给插槽内容
在这里插入图片描述

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值