【element ui】input输入控件绑定粘贴事件,从 Excel 复制的数据粘贴到输入框(el-input)时自动转换为逗号分隔的数据

目录

1、需求

在 Vue 2 和 Element UI 中,要实现从 Excel 复制空格分隔的数据,并在粘贴到输入框(el-input)时自动转换为逗号分隔的数据

2、实现思路:

  1. <el-input/ >组件是由外层< div >和内层的< input>组成的,
    根据浏览器的事件传递机制(先捕获,后冒泡):粘贴的时候会先执行绑定在外层div上的paste事件捕获方法, 然后再到内层的input,
    因此可以在组件上捕获监听paste事件,
  2. 在 paste 事件处理函数中,获取剪贴板中的文本数据,
  3. 将空格分隔的数据转换为逗号分隔的数据,
  4. 将转换后的数据赋值给 v-model 绑定的变量。

3、控件绑定粘贴事件

html 复制代码
  <el-input
            v-model="storesName"
            clearable
            style="margin-left: 6px;width: 40rem"
            placeholder="请输入编码或名称,多项输入以英文,号间隔"
            class="details-input"
            @paste.native="handlePaste"
          />

事件修饰符说明:

native: 表明这个是dom的原生事件,如果不加native, vue会认为paste是一个自定义事件,必须要在组件内手动触发, 那么在粘贴的时候自然就不会触发了

4、代码实现

javascript 复制代码
    handlePaste(e) {
      // 阻止默认粘贴行为(可选,取决于你是否需要立即显示原始数据)
      e.preventDefault()
      // 获取剪贴板中的文本数据
      const text = (e.originalEvent || e).clipboardData.getData('text/plain').trim()
      console.log(text, '文本粘贴')
      // 将空格分隔的数据转换为逗号分隔的数据
      const replacedText = text.replace(/\s+/g, ',')
      // 将转换后的数据赋值给 inputValue
      this.storesName = replacedText
    },

handlePaste 方法会阻止默认的粘贴行为,然后获取粘贴板上的文本。接着,使用 String.prototype.replace 方法和一个正则表达式 \s+ 来匹配一个或多个空格字符,并将它们替换为英文逗号。最后,将处理后的文本赋值给 inputValue。

/\s+/g 是一个正则表达式,用于匹配一个或多个空白字符(包括空格、制表符、换行符等)。这个正则表达式使用了两个特殊的字符:

\s:匹配任何空白字符。

+:表示匹配一个或多个前面的字符(在这里是 \s)。

g:表示全局搜索,即替换所有匹配的项,而不仅仅是第一个。

在代码中,text.replace(/\s+/g, ',') 的作用是将字符串 text 中所有连续的空白字符替换为一个英文逗号 ,。

参考文章:
elementui输入控件绑定粘贴事件对复制数据做处理
阻止element组件中的的粘贴功能
vue element-ui 后台中实现点击按钮,将文本内容复制到剪贴板

🚀写在最后

希望我的分享能够帮助到更多的人,如果觉得我的分享有帮助的话,请大家一键三连支持一下哦~
❤️原创不易,期待你的关注与支持~
点赞👍+收藏⭐️+评论✍️
😊之后我会继续更新前端学习小知识,关注我不迷路~

相关推荐
qq_316837751 天前
Element-Plus el-table lazy 自动更新子列表
前端·vue.js·elementui
阿奇__2 天前
elementUI table 多列排序并保持状态样式显示正确(无需修改源码)
前端·vue.js·elementui
H@Z*rTE|i3 天前
elementUi 当有弹窗的时候提示语被覆盖的问题
前端·javascript·elementui
阿奇__3 天前
vue2+elementUI table多个字段排序
前端·javascript·elementui
J总裁的小芒果3 天前
原生Table写一行保证两条数据
javascript·vue.js·elementui
沐墨染3 天前
大型数据分析组件前端实践:多维度检索与实时交互设计
前端·elementui·数据挖掘·数据分析·vue·交互
南玖i3 天前
SuperMap iServer + vue3 实现点聚合 超简单!
javascript·vue.js·elementui
麻瓜呀4 天前
vue2之el-table表格多选改单选
javascript·vue.js·elementui
weixin_584121434 天前
vue3+elementui+js自定义穿梭框布局
javascript·vue.js·elementui
qq_401967385 天前
element-plus table组件 封装列隐藏功能,并非 v-if 或 v-for,通过tableRef 与样式控制
javascript·vue.js·elementui