前端js 输入框限制(只能输入数字,10位小数,除0[0-9]、.、--、-0[0-9]、-.不能开头外,其他的都可以)?

可以使用如下正则表达式来限制输入框的输入内容:

/^(?!0\d|\.-|\.\.|-0\d|-)(?!.*\.\..*)(?!.*--.*)(?!.*-$)([1-9][0-9]*|0)(\.[0-9]{0,10})?$/

该正则表达式的解释如下:

const input = document.querySelector('#myInput');

input.addEventListener('input', (event) => {

const value = event.target.value;

const isValid = /^(?!0\d|\.-|\.\.|-0\d|-)(?!.*\.\..*)(?!.*--.*)(?!.*-$)([1-9][0-9]*|0)(\.[0-9]{0,10})?$/.test(value);

if (!isValid) {

event.target.value = value.slice(0, -1); // 阻止输入

}

});

在这个例子中,我们首先获取了一个 id 为 myInput 的输入框,并添加了一个 input 事件监听器。在事件处理程序中,我们获取了输入框的值,并使用正则表达式对其进行验证。如果验证失败,我们阻止输入,即将输入框的值设为原来的值减去最后一位。这样,就能够实现对输入框的限制。



可以使用正则表达式来实现输入框限制,以下是一个符合要求的正则表达式:

javascriptCopy code/^(?!0\d)(?!.*\.\.)(?!.*\-\-)(?!0+\d)(?!.*\-\.)[1-9]\d*(\.\d{1,10})?$/

解释一下:



请采纳
可以使用如下正则表达式来限制输入框的输入内容:
/^(?!0\d|\.-|\.\.|-0\d|-)(?!.*\.\..*)(?!.*--.*)(?!.*-$)([1-9][0-9]*|0)(\.[0-9]{0,10})?$/

扩展阅读:做js是什么意思 ... 前端js 和后端js 的区别 ... js 延迟几秒执行 ... js输入框只能输入数字 ... js 对话框中加入输入框 ... js 点击切换显示和隐藏 ... 基于dom的xss漏洞 ... 为什么按了win+r动不了了 ... js 阻止默认事件 ...

本站交流只代表网友个人观点,与本站立场无关
欢迎反馈与建议,请联系电邮
2024© 车视网