Select对于onChange的prop进行警告

一、环境准备

vue + ant-design-vue

二、问题警告

Vue warn\]: Invalid prop: type check failed for prop "onChange". Expected Function, got Array at \

html 复制代码
// parent.vue
<template>
    <CustomUserSelect />
</template>

// CustomUserSelect.vue
<template>
  <Select @change="handleChange" placeholder="请选择" allowClear>
    <SelectOption value="1">1</SelectOption>
    <SelectOption value="2">2</SelectOption>
    <SelectOption value="3">3</SelectOption>
  </Select>
</template>

三、原因分析

使用CustomUserSelect并没有传入,但是控制台会出现 <CustomUserSelect id="customSelectAnthorInfo" onBlur=fn<onBlur8> onChange=fn<onChange9> 会出现一个默认的onChangeonBlur

是UI库(Ant Design Vue)的Select组件内部绑定的事件处理函数,自动绑定到是正常现象,它们用于处理组件的内部逻辑(如当内部发生值变化时触发change事件,当失焦时触发blur事件)

简单来说Select组件会在内部处理一些原生事件(如blur、focus等),并触发自定义事件(如blur、change等)。 在Select组件的模板中,它的根元素可能监听了原生的blur事件,并调用内部方法,然后触发blur事件(自定义事件)

四、解决办法

其实就因为 CustomUserSelect 组件的根元素是 Select ,所以自动绑定了一个onChange9, 而我们又传入了一个 handleChange 方法,vue又会对onChange的方法进行汇总,导致实际传入 onChange=[handleChange, onChange9], 所以报警告,期待的是 Function, 但是传入的是 Array

html 复制代码
// CustomUserSelect 将根元素设置为div 即可消除警告
<template>
  <div>
    <Select @change="handleChange" placeholder="请选择" allowClear>
      <SelectOption value="1">1</SelectOption>
      <SelectOption value="2">2</SelectOption>
      <SelectOption value="3">3</SelectOption>
    </Select>
  </div>
</template>

// 完美解决警告
相关推荐
Warren981 小时前
Lua 脚本在 Redis 中的应用
java·前端·网络·vue.js·redis·junit·lua
mCell2 小时前
JavaScript 运行机制详解:再谈 Event Loop
前端·javascript·浏览器
amy_jork4 小时前
npm删除包
开发语言·javascript·ecmascript
帧栈6 小时前
开发避坑指南(27):Vue3中高效安全修改列表元素属性的方法
前端·vue.js
max5006006 小时前
基于桥梁三维模型的无人机检测路径规划系统设计与实现
前端·javascript·python·算法·无人机·easyui
excel6 小时前
使用函数式封装绘制科赫雪花(Koch Snowflake)
前端
我命由我123456 小时前
软件开发 - 避免过多的 if-else 语句(使用策略模式、使用映射表、使用枚举、使用函数式编程)
java·开发语言·javascript·设计模式·java-ee·策略模式·js
萌萌哒草头将军7 小时前
Node.js v24.6.0 新功能速览 🚀🚀🚀
前端·javascript·node.js
AALoveTouch8 小时前
大麦APP抢票揭秘
javascript
持久的棒棒君8 小时前
启动electron桌面项目控制台输出中文时乱码解决
前端·javascript·electron