时间:2021-05-26
如下图:
1、定义了一个类似下拉的组件 mySelect , 然后里面有自定义的组件 myOptions
2、有很多时候,我们希望, mySelect 组件内部的子组件,只能是 myOptions 。 不应该有 <div>666</div>
3、在mySelect 里面做一层过滤,去掉不需要的组件
下面先看看
myOptions.vue 组件代码
<template> <div class="options"> <div>这里是 options</div> </div></template> <script>// @ is an alias to /srcexport default { name: 'myoptions', data(){ return {} }, created(){ }, mounted(){ }}</script>接下来是 mySelect 的代码:
<template> <div class="select"> <div>这里是 Select</div> <slot></slot> </div></template> <script>// @ is an alias to /src export default { name: "myselect", data(){ return { _children:[] } }, created(){ console.log(this.$children) // 输出为 [] console.log(this.$slots.default) //输出为 [VNode, VNode, VNode] var arr = this.$slots.default || [] var res = []; for(var i = 0; i < arr.length; i++){ var item = arr[i]; if(item.componentOptions && item.componentOptions.tag == "myOptions"){ res.push(item); } } this._children = res; this.$slots.default = res; }, mounted(){ console.log(this.$slots.default) //[VNode, VNode] console.log(this.$children)//因为过滤掉了一个,所以为 [VueComponent, VueComponent] }}</script>在 mySelect 的 created 和 mounted 里面,分别查看
this.$slots.default和 this.$children就会发现内部的子组件渲染,与这个有很大关系,只需要过滤一下 slots 就可以了
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
我们在使用vue开发过程中会遇到这样的情况,在父组件中引入了子组件,需要将父组件的值传到子组件中显示,同时子组件还可以更改父组件的值。以我目前的一个项目的开发为
父组件如何给子组件传值使用props举个例子:子组件:fromTest.vue,父组件app.vuefromTest.vue{{title}}//title必须
本文实例讲述了Vue实现的父组件向子组件传值功能。分享给大家供大家参考,具体如下:Vue父组件向子组件传值Vue.component('todo-item',{
一、父组件向子组件传递数据在Vue中,可以使用props向子组件传递数据。子组件部分:这是header.vue的HTML部分,logo是在data中定义的变量。
一.Vue中父组件向子组件传值利用v-bind向子组件传值,子组件中利用props接受{{name}}{{age}}{{parentname}}{{abc}}/