隐菌子 2022-04-02 00:29 采纳率: 58.3%
浏览 37
已结题

vue多个父组件内使用同一子组件时绑定回调问题

我封装了一个下拉选择器,在父组件内給他绑定了自定义事件,但后续组件复用时,在另外的一个父组件中并不需要这个方法,这引起了我的疑惑,不管某父组件需不需要绑定自定义事件,触发其他的父组件回调的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。
总感觉看着怪怪的,也担心它们间会不会互相影响,请为我讲解一下其中缘由

  • 写回答

3条回答 默认 最新

  • 你好!机器人 2022-04-02 07:02
    关注

    不同组件绑定不同的回调就可以了,如果父组件没定义是不会执行的

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 4月11日
  • 已采纳回答 4月3日
  • 创建了问题 4月2日

悬赏问题

  • ¥15 请问读取环境变量文件失败是什么原因?
  • ¥15 在若依框架下实现人脸识别
  • ¥15 网络科学导论,网络控制
  • ¥100 安卓tv程序连接SQLSERVER2008问题
  • ¥15 利用Sentinel-2和Landsat8做一个水库的长时序NDVI的对比,为什么Snetinel-2计算的结果最小值特别小,而Lansat8就很平均
  • ¥15 metadata提取的PDF元数据,如何转换为一个Excel
  • ¥15 关于arduino编程toCharArray()函数的使用
  • ¥100 vc++混合CEF采用CLR方式编译报错
  • ¥15 coze 的插件输入飞书多维表格 app_token 后一直显示错误,如何解决?
  • ¥15 vite+vue3+plyr播放本地public文件夹下视频无法加载