el-input自动去掉空格,vue项目全局使用

 项目场景:

表单中的输入框如果输入空格自动去掉,但是每个input都加方法就比较麻烦,所以就需要使用vue自带的自定义指令功能

解决方案:

1)先在utils/directive文件夹下创建一个trimjs文件

/**
 * 去除两边空格
 * 使用 <el-input v-model="xxx" v-trim></el-input>
 */
function getInput(el) {
    let inputEle
    if (el.tagName !== 'INPUT') {
          inputEle = el.querySelector('input') || el.querySelector('textarea')
    } else {
          inputEle = el
    }
    return inputEle
}
function dispatchEvent(el, type) {
    let evt = document.createEvent('HTMLEvents')
    evt.initEvent(type, true, true)
    el.dispatchEvent(evt)
}
const Trim = {
    inserted: el => {
          let inputEle = getInput(el)
          const handler = function (event) {
                const newVal = event.target.value.trim()
                if (event.target.value != newVal) {
                      event.target.value = newVal
                      dispatchEvent(inputEle, 'input')
                }
          }
          el.inputEle = inputEle
          el._blurHandler = handler
          inputEle.addEventListener('blur', handler)
    },
    unbind(el) {
          const { inputEle } = el
          inputEle.removeEventListener('blur', el._blurHandler)
    }
}
export default Trim

因为项目自定义的指令比较多防止重复代码

当然如果你想直接引入一个

import trim from ‘对应文件xxx’
Vue.directive(trim, directives[trim])
Vue.use(directives); // 自定义 v-{功能名}

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值