JavaScript验证:数字与字母输入限制总结
5星 · 超过95%的资源 21 浏览量
更新于2024-08-31
收藏 55KB PDF 举报
在JavaScript中,验证用户输入的内容是否仅限于数字和字母是一项常见的任务,特别是在表单验证时。本文将详细介绍几种常见的方法,确保用户在文本框中输入的内容符合特定规则。
首先,我们可以使用`onpaste`事件阻止用户粘贴非数字和字母字符。例如,第一种方法是通过在输入框上添加`onpaste="return false;"`,配合HTML属性`ime-mode: disabled`,阻止IME(输入法)的使用,并使用JavaScript函数`chkIt`来检查输入值:
```javascript
function chkIt(frm) {
if (frm.n1.value.length > 0 && !frm.n1.value.match(/[\x01-\xFF]*/)) { // 匹配ASCII字符,排除中文
alert('n1不能输入中文!');
frm.n1.focus();
return false;
}
}
```
这个函数会在提交表单前检查输入,如果发现中文字符或不符合规则的字符,会给出警告并聚焦到出错的输入框。
接下来,我们可以通过`onkeyup`和`onafterpaste`事件实时清理非数字和小数点字符。例如,第二种方法是使用正则表达式`/\D/g`匹配所有非数字字符,然后清除它们:
```html
<input onkeyup="this.value = this.value.replace(/\D/g, '')" onafterpaste="this.value = this.value.replace(/\D/g, '')">
```
这种方法可以限制用户在输入过程中输入非数字和小数点。
第三种方法结合了`isNaN()`函数和`execCommand('undo')`来防止输入非数字和小数点,同时允许用户输入小数点:
```html
<input onkeyup="if(isNaN(value)) execCommand('undo')" onafterpaste="if(isNaN(value)) execCommand('undo')">
```
`isNaN()`检查输入是否为数字,如果不是,则撤销上一步操作。
最后,第四种方法使用`onkeypress`事件和正则表达式`/^\+\-?\d*?\.?\d*?$/'`,该正则匹配包括正负号、整数和小数的数字形式,如果输入不符合此模式,就重置输入值:
```html
<input type="text" t_value="" onkeyup="if(!this.value.match(/^[\+\-]?\d*?\.?\d*?$/)) this.value = this.t_value; else this.t_value = this.value;">
```
这种方法确保了用户只能输入数字和小数点,且支持正负号。
总结来说,这些JavaScript方法通过不同的事件监听和正则表达式检查,有效地实现了只允许输入数字和字母的验证。在实际开发中,可以根据具体需求选择合适的方法,或者组合使用,以达到最佳的用户体验和数据有效性。
2020-10-22 上传
2020-11-23 上传
2012-12-24 上传
2011-04-29 上传
点击了解资源详情
点击了解资源详情
2020-10-24 上传
2014-05-22 上传
weixin_38608866
- 粉丝: 7
- 资源: 915
最新资源
- S7_PLCSIM_V54_SP3.rar
- 背包清单:我冒险中的背包装备清单
- quartz-boiler:Quartz Spring集成样板代码
- RestAssured_RahulShetty:udemy API自动化测试教程中的所有程序
- electronjs-todo-app:用ElectronJS制作的简单待办事项应用
- .dotfiles
- Pixelreka! -使用TogetherJS JavaScript库进行实时游戏
- MaxKMeans:解决k-means问题的算法
- Python库 | funkload-1.4.1-py2.4.egg
- 塞尔达测验应用
- future-robotics:未来机器人燃烧人营创建的项目集合
- moulalehero
- eslint-config-tron:具有TypeScript,Hooks和Prettier支持的Tron的ESLint配置
- Sluglords-Of-Thras(萨卢格洛德·斯格拉格斯):萨洛斯之怒(Glroy to Thras)和伟大的失落者
- 易语言绝地求生全套加速器源码
- gemini_bot_list:我尝试列出双子星机器人和代理的IP地址的github回购。 在Github上,可能比在Codeberg上能贡献更多的人