vue父子组件slot插槽的使用
vue父子组件slot插槽
关于父组件在使用子组件的时候,向子组件插入内容的方法
1.创建一个子组件并在vue实例中注册
这是创建子组件
var testzujian = { template:`<div> <span>这是子组件的内容</span> </div>` }
这是注册子组件
let vm = new Vue({ el:'.root', components:{ testzujian:testzujian }, })
2.在HTML代码中使用子组件
<body> <div class="root"> <testzujian></testzujian> </div> </body>
3.在vue实例中写入想要插入到子组件的内容
let vm = new Vue({ el:'.root', components:{ testzujian:testzujian }, template:`<div> <testzujian> <template v-slot:slotcontent> <span>这是父组件向子组件插入的内容</span> </template> </testzujian> </div>`, })
其中template是一个模板字符串,这个模板字符串里面最外面的div标签是根目录,必须存在。
根目录之下的是已经注册的子组件,也是需要加内容的子组件标签,必须存在
子组件标签之内的也是必须存在的
其上的属性v-slot绑定了一个名字slotcontent,这个名字可以随意取,但必须得有
这个标签里面就用来添加
父组件想要插入子组件的内容
4.在子组件的模板中通过一个slot标签
来引入父组件模板中内添加的内容
var testzujian = { template:`<div> <span>这是子组件的内容</span> <slot name="slotcontent"> </slot> </div>` }
这是刚才创建好的子组件,现在在其template的模板中,加入了一个slot标签,属性name绑定为刚才中v-slot:绑定的名字,也就是slotcontent
vue插槽v-slot实现父向子传值
// 子组件代码 <template> <div class="child"> <h4>this is child component</h4> <p>收到来自父组件的消息: <slot name="child"></slot> <!--展示父组件通过插槽传递的{{message}}--> </p> </div> </template>
//父组件代码 <template> <div class="parent"> <h3>this is parent component</h3> <input type="text" v-model="message" /> <Child> <template v-slot:child> {{ message }} <!--插槽要展示的内容--> </template> </Child> </div> </template>
<script> import Child from './child' export default { name: 'Parent', data() { return { message: '内容', } }, components: { Child, }, } </script>
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
详解vue-template-admin三级路由无法缓存的解决方案
这篇文章主要介绍了vue-template-admin三级路由无法缓存的解决方案,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧2020-03-03Vue + element实现动态显示后台数据到options的操作方法
最近遇到一个需求需要实现selector选择器中选项值options 数据的动态显示,而非写死的数据,本文通过实例代码给大家分享实现方法,感兴趣的朋友一起看看吧2021-07-07vue按需加载组件webpack require.ensure的方法
本篇文章主要介绍了vue按需加载组件webpack require.ensure的方法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下2017-12-12
最新评论