Vue中el-input的相关校验使用场景

1、输入框只能输入数字且第一位不能为小数点,以及只能输入小数点后两位

<el-input v-model="item.amount" type="number" @keyup.native='keyupEvent($event,item.amount)'></el-input>
//只能输入小数点后两位
keyupEvent(e,input){
  e.target.value=e.target.value.replace(/[^\d.]/g, '');
  e.target.value=e.target.value.replace(/\.{2,}/g, '.');
  e.target.value=e.target.value.replace(/^\./g, '0.');
  e.target.value=e.target.value.replace(/^\d*\.\d*\./g, e.target.value.substring(0,e.target.value.length-1));
  e.target.value=e.target.value.replace(/^0[^\.]+/g, '0');
  e.target.value=e.target.value.replace(/^(\d+)\.(\d\d).*$/, '$1.$2');
  input=e.target.value;
},

2、编辑输入框触发事件:比如在输入框1输入内容,同页面某地方需要响应改变的场景(结合计算属性)

<el-input v-model="item.amount" type="number" v-on:input="receiInput(item)"></el-input>
computed: {//计算属性
  computedAmount() {
    return function(oldSum,newSum){
      return oldSum-newSum;
    }
  },
},
methods:{
	receiInput(item){
		this.newTotal=this.computedAmount(item.amount1,item.amount2);
	},
}

3、输入框失去聚焦时触发事件

<el-input v-model="item.amount" type="number" @blur="changeInput(item)"></el-input>
//失去聚焦时响应
changeInput(item){
  //失去聚焦时做的操作
  if(item.amount <=0){
    this.$message.error("商家应收金额需大于0,请重新填写");
  }
},

4、只能输入非负整数和限制数值范围(直接简便使用el-input-number 标签)

<el-input-number 
  v-model="form.gtalalmTime"
  :precision="0" //只能输入整数
  style="width: 50%" 
  controls-position="right" //输入框样式
  :min="0" //最小值
  :max="9999"//最大值
>
</el-input-number>
  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Vue是一种流行的JavaScript框架,用于构建用户界面。它采用了组件化的开发方式,使得开发者可以将页面拆分成独立的、可复用的组件。el-table是Vue的一个表格组件,而el-input是一个输入框组件。 在el-table使用el-input进行行内校验的方法如下: 1. 首先,在el-table的每一行使用el-input组件来渲染需要进行校验的单元格。 2. 在el-input使用Vue校验指令(如v-model和:rules)来实现校验功能。 3. 在Vue实例定义校验规则,并将其应用到el-input上。 下面是一个示例代码: ```html <template> <el-table :data="tableData"> <el-table-column prop="name" label="姓名"> <template slot-scope="scope"> <el-input v-model="scope.row.name" :rules="nameRules"></el-input> </template> </el-table-column> <el-table-column prop="age" label="年龄"> <template slot-scope="scope"> <el-input v-model="scope.row.age" :rules="ageRules"></el-input> </template> </el-table-column> </el-table> </template> <script> export default { data() { return { tableData: [ { name: '张三', age: 20 }, { name: '李四', age: 25 }, // ... ], nameRules: [ { required: true, message: '姓名不能为空', trigger: 'blur' }, // 其他校验规则 ], ageRules: [ { required: true, message: '年龄不能为空', trigger: 'blur' }, // 其他校验规则 ] }; } }; </script> ``` 在上述代码,我们使用el-table组件来展示数据,并在每一列使用el-input组件进行编辑。通过给el-input组件绑定v-model指令,可以实现数据的双向绑定。同时,通过给el-input组件绑定:rules指令,可以定义校验规则。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Spring_z7

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值