Vue中slot是什么?有什么作用?原理是什么?

slot又名插槽,是Vue的内容分发机制,组件内部的模板引擎使用slot元素作为承载分发内容的出口。插槽slot是子组件的一个模板标签元素,而这一个标签元素是否显示,以及怎么显示是由父组件决定的。slot又分三类,默认插槽,具名插槽和作用域插槽。

  • 默认插槽:又名匿名查抄,当slot没有指定name属性值的时候一个默认显示插槽,一个组件内只有有一个匿名插槽。
  • 具名插槽:带有具体名字的插槽,也就是带有name属性的slot,一个组件可以出现多个具名插槽。
  • 作用域插槽:默认插槽、具名插槽的一个变体,可以是匿名插槽,也可以是具名插槽,该插槽的不同点是在子组件渲染作用域插槽时,可以将子组件内部的数据传递给父组件,让父组件根据子组件的传递过来的数据决定如何渲染该插槽。

实现原理: 当子组件vm实例化时,获取到父组件传入的slot标签的内容,存放在vm.$slot中,默认插槽为vm.$slot.default,具名插槽为vm.$slot.xxx,xxx 为插槽名,当组件执行渲染函数时候,遇到slot标签,使用$slot中的内容进行替换,此时可以为插槽传递数据,若存在数据,则可称该插槽为作用域插槽。

相关推荐
子林super16 分钟前
mongo创建安全扫描账号手册
前端
用户408128120038118 分钟前
登录权限设置
前端
对我的心脏有害20 分钟前
我偷偷给公司项目用了自己写的状态管理库,同事:结局舒服了
vue.js·react.js
YYYYY7788320 分钟前
React Scheduler 原理解读
前端·react.js
子林super20 分钟前
Doris-ansible自动化部署脚本
前端
子林super20 分钟前
Doris-FE节点滚动重启
前端
好青崧21 分钟前
框架和库的区别
vue.js
好青崧32 分钟前
vue的优缺点
前端·javascript·vue.js
好青崧33 分钟前
vue是什么
前端·javascript·vue.js
对我的心脏有害42 分钟前
这个 React 状态管理库让我少写一半代码,同事问我是不是开挂了
vue.js·react.js