el-input仅限输入数字 (输入框仅支持输入数字)

需求:日常开发中会遇到输入框只能输入数字的功能。常用的方法有下面几种

  • 方式1 (将输入框类型改成number)
javascript 复制代码
<el-input v-model="number" type="number"/>
  • 方式2 (使用正则控制) 推荐使用该方式
javascript 复制代码
 <el-input v-model="value1" placeholder="请输入" @input.native="onInput"/>
 
const value1 = ref('')
// 定义输入处理函数
function onInput(event) {
  value1.value = event.replace(/[^\d.]/g, '');
  console.log(event, 'event', value1.value)
}
  • 方式3 (使用oninput来实现)
javascript 复制代码
<el-input v-model="amount" type="text" oninput="value=value.replace(/[^\d.]/g,'')"/>

比较推荐方式二 用正则的方式来做,方式三会有一个问题就是先输入汉字在输入数字,这个时候打印输入框绑定的值就会是空的,用方式二不会出现这个问题,方式一 加上number之后会出现上下箭头,需要用css隐藏过于麻烦而且可能会影响其他样式(不推荐)

相关推荐
余人于RenYu6 小时前
Claude + Figma MCP
前端·ui·ai·figma
杨艺韬9 小时前
vite内核解析-第2章 架构总览
前端·vite
我是伪码农10 小时前
外卖餐具智能推荐
linux·服务器·前端
qq_2837200510 小时前
Python Celery + FastAPI + Vue 全栈异步任务实战
vue.js·python·fastapi
2401_8858850410 小时前
营销推广短信接口集成:结合营销策略实现的API接口动态变量填充方案
前端·python
小李子呢021110 小时前
前端八股性能优化(2)---回流(重排)和重绘
前端·javascript
程序员buddha11 小时前
深入理解ES6 Promise
前端·ecmascript·es6
吴声子夜歌11 小时前
ES6——Module详解
前端·ecmascript·es6
剪刀石头布啊11 小时前
原生form发起表单干了啥
前端
剪刀石头布啊11 小时前
表单校验场景,如何实现页面滚动到报错位置
前端