软件教程 2025年08月6日
0 收藏 0 点赞 773 浏览 1990 个字
摘要 :

文章目录 解决方法: 方法一: 方法二(懒人推荐): 本文主要讲解关于vue3项目如何去除el–input前后空格相关内容,让我们来一起学习下吧! 一看到这个需求,心……




  • 解决方法:
  • 方法一:
  • 方法二(懒人推荐):

本文主要讲解关于vue3项目如何去除elinput前后空格相关内容,让我们来一起学习下吧!

一看到这个需求,心想这个多简单呀。第一想法就是v-model.trim。然而被测试同学打回来了。

需求是:去除前后空格,但是可以保留中间部分的空格。

解决方法:

方法一:

如果没有其他复杂的需求,仅仅在页面使用el-input组件,那么可以全局二次封装一个简单的处理方法。

<template>
  <el-input v-model=\"modelValue\" @blur=\"hBlur\" v-bind=\"$attrs\">
    
  </el-input>
</template>
<script setup>
import { computed } from \'vue\';
const props = defineProps({
  modelValue: {
    type: String,
    default: \'\',
  },
});
const emit = defineEmits([\'update:modelValue\']);
const modelValue = computed({
  get() {
    return props.modelValue;
  },
  set(v) {
    emit(\'update:modelValue\', v);
  },
});
const hBlur = () => {
  modelValue.value = modelValue.value.trim();
};
</script>

缺点:
这种方式如果是涉及到#append等自定义内容,还得去重复封装一下。(关键是我是系统全部功能都开发完了之后,才接收到这个bug的,难道我要一个个页面去调试替换么?)对于我那么懒惰的人来说是绝对不可能的。

方法二(懒人推荐):

全局指令

function getInput(el: any) {
  let inputEle;
  if (el.tagName !== \'INPUT\') {
    inputEle = el.querySelector(\'input\');
  } else {
    inputEle = el;
  }
  return inputEle;
}
function clearTrim(inputEle: any) {
  inputEle.value = inputEle.value.trim(); //这里会存在input框中的内容改了,但是v-model绑定的值没有被更改到
}
export const trim: Directive = {
  mounted(el) {
    let inputEle = getInput(el);
    const blurHandler = function () {
      clearTrim(inputEle);
    };
    const enterHandler = function (e: { keyCode: number }) {
      if (e.keyCode === 13) {
        clearTrim(inputEle);
      }
    };
    inputEle._blurHandler = blurHandler;
    inputEle._enterHandler = enterHandler;
    inputEle.addEventListener(\'blur\', blurHandler);
    inputEle.addEventListener(\'keydown\', enterHandler);
  },
  unmounted(el) {
    let inputEle = getInput(el);
    inputEle.removeEventListener(\'blur\', inputEle._blurHandler);
    inputEle.removeEventListener(\'keydown\', inputEle._enterHandler);
  },
};

遇到的问题:input框中的内容改了,但是v-model绑定的值没有被更改到


function dispatchEvent(el, type) {
      let evt = document.createEvent(\'HTMLEvents\')
      evt.initEvent(type, true, true)
      el.dispatchEvent(evt)
}

 // 修改value值之后调用
   dispatchEvent(inputEle, \'input\')

问题:initEvent()方式已经被弃用

正确解决方法:

function dispatchEvent(el: any, type: string) {
  let evt = new Event(type, {
    bubbles: true,
    cancelable: true,
    composed: true,
  });
  el.dispatchEvent(evt); //手动触发input时间
}

以上就是关于vue3项目如何去除el-input前后空格相关的全部内容,希望对你有帮助。欢迎持续关注潘子夜个人博客(www.panziye.com),学习愉快哦!

微信扫一扫

支付宝扫一扫

版权: 转载请注明出处:https://www.zuozi.net/6606.html

管理员

相关推荐
2025-08-06

文章目录 一、Promise基础回顾 二、Promise 与 axios 结合使用场景及方法 (一)直接返回 axios …

269
2025-08-06

文章目录 一、模块初始化时的内部机制 二、常见导出写法的差异分析 (一)写法一:module.exports…

107
2025-08-06

文章目录 一、ResizeObserver详解 (一)ResizeObserver是什么 (二)ResizeObserver的基本用法 …

683
2025-08-06

文章目录 一、前期准备工作 (一)下载相关文件 (二)安装必要工具 二、处理扣子空间生成的文件…

338
2025-08-06

文章目录 一、官方文档 二、自动解包的数据类型 ref对象:无需.value即可访问 reactive对象:保持…

371
2025-08-06

文章目录 一、Hooks的工作原理 二、在if语句中使用Hook会出什么岔子? 三、React官方的Hook使用规…

843
发表评论
暂无评论

还没有评论呢,快来抢沙发~

助力内容变现

将您的收入提升到一个新的水平

点击联系客服

在线时间:08:00-23:00

客服QQ

122325244

客服电话

400-888-8888

客服邮箱

122325244@qq.com

扫描二维码

关注微信客服号