el-input添加自定义指令只允许输入中文/英文/数字,兼容输入法事件

省流

script:

javascript 复制代码
directives: {
 regexp: {
   inserted: (el, binding, vnode) => {
     let composition = false
     const formatValue = function (e) {
       if (composition) return
       // vnode.componentInstance组件实例
       vnode.componentInstance.$emit('input', e.target.value.replace(/[^\u4e00-\u9fa5a-zA-Z0-9/]/g, ''))
     }
     el.oninput = formatValue
     // 请务必使用addEventListenner,不信邪你试试el.oncompositionstart
     el.addEventListener('compositionstart', () => { composition = true })
     el.addEventListener('compositionend', e => {
       composition = false
       formatValue(e)
     })
   }
 }
}

template:

html 复制代码
<el-input v-regexp />

有问题欢迎指出

相关推荐
未来龙皇小蓝42 分钟前
RBAC前端架构-05:引入Element-UI及相关逻辑
前端·ui
yanlele1 小时前
AI Coding 时代下, 关于你会写代码这件事儿, 还重要吗?
前端·javascript·ai编程
打瞌睡的朱尤2 小时前
Vue day9 购物车,项目,vant组件库,vw,路由
前端·javascript·vue.js
星火开发设计4 小时前
模板参数:类型参数与非类型参数的区别
java·开发语言·前端·数据库·c++·算法
cc.ChenLy6 小时前
【CSS进阶】毛玻璃效果与代码解析
前端·javascript·css
何中应6 小时前
使用Jenkins部署前端项目(Vue)
前端·vue.js·jenkins
西门吹-禅6 小时前
node js 性能处理
开发语言·javascript·ecmascript
3秒一个大6 小时前
JWT 登录:原理剖析与实战应用
前端·http·代码规范
一只大侠的侠6 小时前
React Native for OpenHarmony:日期范围选择器实现
javascript·react native·react.js
NEXT066 小时前
2026 技术风向:为什么在 AI 时代,PostgreSQL 彻底成为了全栈工程师的首选数据库
前端·数据库·ai编程