需求:
一个el-input,小数点的保留几位的位数用变量来表示;
```javascript
<el-input
v-model="num"
placeholder="请输入内容"
type="text"
@input="limitInput($event)"
v-model.trim="num"
size="small"
width="50"
></el-input>
以下,能够实现保存2位小数,现在要把match方法里的2变成变量;
limitInput(value) {
this.num =
("" + value) // 第一步:转成字符串
.replace(/[^\d^\.]+/g, "") // 第二步:把不是数字,不是小数点的过滤掉
.replace(/^0+(\d)/, "$1") // 第三步:第一位0开头,0后面为数字,则过滤掉,取后面的数字
.replace(/^\./, "0.") // 第四步:如果输入的第一位为小数点,则替换成 0. 实现自动补全
.match(/^\d*(\.?\d{0,2})/g)[0] || ""; // 第五步:最终匹配得到结果 以数字开头,只有一个小数点,而且小数点后面只能有0到2位小数
}
以下是最终结果
limitInput(value) {
let reg = new RegExp("^\\d*(\\.?\\d{0," + this.decimal + "})", "g");
this.num =
("" + value) // 第一步:转成字符串
.replace(/[^\d^\.]+/g, "") // 第二步:把不是数字,不是小数点的过滤掉
.replace(/^0+(\d)/, "$1") // 第三步:第一位0开头,0后面为数字,则过滤掉,取后面的数字
.replace(/^\./, "0.") // 第四步:如果输入的第一位为小数点,则替换成 0. 实现自动补全
.match(reg)[0] || ""; // 第五步:最终匹配得到结果 以数字开头,只有一个小数点,而且小数点后面只能有0到2位小数
}