客户管理系统开发定制el-input 只能输入整数(包括正数、负数、0)或者只能输入整数(包括正数、负数、0)和小数

客户管理系统开发定制我们可以优先使用el-input-number标签


客户管理系统开发定制支持很多属性可以到官网查看

客户管理系统开发定制也可以使用type=numbe和v-model.number属性,客户管理系统开发定制两者结合使用,客户管理系统开发定制能满足大多数需求,如果还不满足,可以再结合正则表达式过滤

<el-input v-model.number="value" type="number" />
  • 1

el-input标签type=number或者v-.number属性,可能也没有完全符合我们想要的结果,所以直接使用正则表达式过滤

<el-input v-model="height" placeholder="请输入" @input="handleEdit" />
  • 1

el-input 只能输入正整数(包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\d]/g, ""); // 只能输入数字      value = value.replace(/^0+(\d)/, "$1"); // 第一位0开头,0后面为数字,则过滤掉,取后面的数字      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

el-input 只能输入正整数(不包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/^(0+)|[^\d]+/g,''); // 以0开头或者输入非数字,会被替换成空      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6

el-input 只能输入负整数(包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d]/g, ""); // 只能输入-和数字      value = value.replace(/^[1-9]/g, ""); // 不能以1-9开头      value = value.replace(/\-{2,}/g, "-"); // -只能保留一个      value = value.replace(/(\d)\-/g, "$1"); // 数字后面不能接-,不能出现类似-11-2,12-,11-23      value = value.replace(/-(0+)/g, "0"); // 不能出现-0,-001,-0001类似      value = value.replace(/^0+(\d)/, "0"); // 第一位0开头,0后面为数字,则过滤掉,取0      value = value.replace(/(-\d{15})\d*/, '$1') // 最多保留15位整数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

el-input 只能输入负整数(不包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d]/g, ""); // 只能输入-和数字      value = value.replace(/^\d/g, ""); // 不能以数字开头      value = value.replace(/\-{2,}/g, "-"); // -只能保留一个      value = value.replace(/(\d)\-/g, "$1"); // 数字后面不能接-,不能出现类似-11-2,12-,11-23      value = value.replace(/(-)0+/g, "$1"); // 不能出现-0,-001,-0001类似      value = value.replace(/(-\d{15})\d*/, '$1') // 最多保留15位整数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

el-input 只能输入整数(包括正整数、负整数、0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d]/g, ""); // 只能输入-和数字      value = value.replace(/\-{2,}/g, "-"); // -只能保留一个      value = value.replace(/(\d)\-/g, "$1"); // 数字后面不能接-,不能出现类似-11-2,12-,11-23      value = value.replace(/-(0+)/g, "0"); // 不能出现-0,-001,-0001类似      value = value.replace(/^0+(\d)/, "$1"); // 第一位0开头,0后面为数字,则过滤掉,取后面的数字      value = value.replace(/(-?\d{15})\d*/, '$1') // 最多保留15位整数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10

el-input 只能输入正小数(包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\d.]/g, '') // 只能输入数字和.      value = value.replace(/^\./g, '')  //第一个字符不能是.      value = value.replace(/\.{2,}/g, '.') // 不能连续输入.      value = value.replace(/(\.\d+)\./g, '$1') // .后面不能再输入.      value = value.replace(/^0+(\d)/, '$1') // 第一位0开头,0后面为数字,则过滤掉,取后面的数字      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      value = value.replace(/(\.\d{2})\d*/, '$1')// 最多保留2位小数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

el-input 只能输入负小数(包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d.]/g, ""); // 只能输入-和数字和.      value = value.replace(/^[^\-0]/g, ""); // 只能-和0开头      value = value.replace(/\-{2,}/g, "-"); // 不能连续输入-      value = value.replace(/(-)\./g, "$1"); // -后面不能输入.      value = value.replace(/\.{2,}/g, "."); // 不能连续输入.      value = value.replace(/(\.\d+)\./g, "$1"); // .后面不能再输入.      value = value.replace(/(\d+|\.)-/g, "$1"); // 数字和.后面不能接-,不能出现类似11-, 12.-      value = value.replace(/(-)0+(\d+)/g, '$1$2') // 不能出现-01,-02类似      value = value.replace(/^0+(\d|.)/, "0"); // 第一位0开头,0后面为数字或者.,则过滤掉,取0      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      value = value.replace(/(\.\d{2})\d*/, '$1')// 最多保留2位小数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15

el-input 只能输入负小数(不包括0)

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d.]/g, ""); // 只能输入-和数字和.      value = value.replace(/^[^\-]/g, ""); // 只能-开头      value = value.replace(/\-{2,}/g, "-"); // 不能连续输入-      value = value.replace(/(-)\./g, "$1"); // -后面不能输入.      value = value.replace(/\.{2,}/g, "."); // 不能连续输入.      value = value.replace(/(\.\d+)\./g, "$1"); // .后面不能再输入.      value = value.replace(/(\d+|\.)-/g, "$1"); // 数字和.后面不能接-,不能出现类似11-, 12.-      value = value.replace(/(-)0+(\d+)/g, '$1$2') // 不能出现-01,-02类似      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      value = value.replace(/(\.\d{2})\d*/, '$1')// 最多保留2位小数      this.height = value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14

el-input 输入整数(包括正数、负数、0)和小数,保留15位整数和2位小数

// 在 Input 值改变时触发handleEdit(e) {      let value = e.replace(/[^\-\d.]/g, '') // 只能输入.和-和数字      value = value.replace(/^\./g, '')  //第一个字符不能是.      value = value.replace(/\.{2,}/g, '.') // 不能连续输入.      value = value.replace(/(\.\d+)\./g, '$1') // .后面不能再输入.      value = value.replace(/(-)\./g, '$1') // -后面不能输入.      value = value.replace(/\-{2,}/g, '-') // -只能保留一个      value = value.replace(/(\d+|\.)-/g, '$1') // 数字和.后面不能接-,不能出现类似11-, 12.-      value = value.replace(/-(0){2,}/g, "$1") // 不能出现-00,-001,-0001类似      value = value.replace(/(-)0+(\d+)/g, '$1$2') // 不能出现-01,-02类似      value = value.replace(/^0+(\d)/, '$1') // 第一位0开头,0后面为数字,则过滤掉,取后面的数字      value = value.replace(/(\d{15})\d*/, '$1') // 最多保留15位整数      value = value.replace(/(\.\d{2})\d*/, '$1')// 最多保留2位小数      this.height= value}
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16

$1表示匹配第一个括号里的内容,$2表示匹配第二个括号的内容,比如

value = value.replace(/(-)\./g, '$1') // 输入框输入-.就会替换成-value = value.replace(/(-)(0{2,})/g, '$1$2') // 输入-00,-000,就会替换成-0
  • 1
  • 2

写得有点复杂,没办法,刚上手的正则表达式。如果配合el-input标签的type=number或者v-model.number属性,正则表达式部分也许不用写这么多而且复杂。有更简洁的方法请评论区留言
附上:


网站建设定制开发 软件系统开发定制 定制软件开发 软件开发定制 定制app开发 app开发定制 app开发定制公司 电商商城定制开发 定制小程序开发 定制开发小程序 客户管理系统开发定制 定制网站 定制开发 crm开发定制 开发公司 小程序开发定制 定制软件 收款定制开发 企业网站定制开发 定制化开发 android系统定制开发 定制小程序开发费用 定制设计 专注app软件定制开发 软件开发定制定制 知名网站建设定制 软件定制开发供应商 应用系统定制开发 软件系统定制开发 企业管理系统定制开发 系统定制开发