我封装了一个下拉选择器,在父组件内給他绑定了自定义事件,但后续组件复用时,在另外的一个父组件中并不需要这个方法,这引起了我的疑惑,不管某父组件需不需要绑定自定义事件,触发其他的父组件回调的emit方法都要写在子组件内,要是有多个父组件都需要绑定自定义事件的话,岂不是要在子组件内写多个emit方法去触发不同的自定义事件,让我很疑惑
A父组件給子组件绑定自定义事件
<v-select
:options="selectSettings.options"
:isSelected.sync="selectSettings.value"
:settings="selectSettings.settings"
@select="getData"
>
</v-select>
B父组件不需要自定义事件
<v-select
:options="selectSettings.options"
:isSelected.sync="selectSettings.value"
:settings="selectSettings.settings"
style="width: 100%"
>
</v-select>
下拉选择器组件内变化时调用父组件自定义事件
handeleChange(e) {
//改变父value
this.$emit("update:isSelected", e);
//父数据更新
this.$emit("select");
},
就是这种情况,即时B父组件不需要自定义事件,子组件内仍然要有A父组件的emit,
假如还有个C父组件也需要自定义方法,那么在子组件内就还要增加C父组件的emit。
总感觉看着怪怪的,也担心它们间会不会互相影响,请为我讲解一下其中缘由
不同组件绑定不同的回调就可以了,如果父组件没定义是不会执行的
这个不定义就不会执行啊,可以类比同一个值,使用不同的变量传值,自己能区分就行
相当于你要发明一个即可以蒸米饭也可以煮粥的电饭煲,有的人要用它蒸米饭,有的人要用它煮粥,有的人既要蒸米饭又要煮粥,他们没冲突的。
你还可以再升级一下,这个电饭煲还可以煲汤,但是别人可能不需要这个功能,但是别人不需要就要把这个功能去掉吗?
一个组件可能有多个功能,需要哪个就用哪个