浏览 7417 次
锁定老帖子 主题:文本框中禁止使用输入法
精华帖 (0) :: 良好帖 (0) :: 新手帖 (0) :: 隐藏帖 (0)
|
|
---|---|
作者 | 正文 |
发表时间:2012-06-11
今天碰到一个问题,在一个文本框中要求只能输入数字,于是我做了如下限制
1、在文本框上添加处理函数onkeypress="onlyNumberAndCharInput() 2、在JS中添加对应的function //仅输入数字和字母
function onlyNumberAndCharInput() { if ((event.keyCode>=48 && event.keyCode<=57) || (event.keyCode>=65 && event.keyCode<=90) || (event.keyCode>=97 && event.keyCode<=122)) { event.returnValue=true; } else { event.returnValue=false; } } 但是测试告诉我说这个时候可以输入汉字,让修改下,于是又加上了禁用输入法
style="ime-mode:disabled"
声明:ITeye文章版权属于作者,受法律保护。没有作者书面许可不得转载。
推荐链接
|
|
返回顶楼 | |
发表时间:2012-07-02
哪有这么麻烦
js版 <input type="text" onkeyup="value=value.replace(/[^0-9.]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^0-9.]/g,''))"/> jQuery版 $(function() { $('.integer').bind({ keyup : function() { $(this).val($(this).val().replace(/[^\d]/g, '')); } }); $('.integer').each(function() { var _input = $(this)[0]; if (_input.attachEvent) { _input.attachEvent('onbeforepaste', formatPasteDataToInteger); } else { _input.addEventListener('onbeforepaste', formatPasteDataToInteger, false); } }); $('.float').bind({ keyup : function() { $(this).val($(this).val().replace(/[^0-9.]/g, '')); } }); $('.float').each(function() { var _input = $(this)[0]; if (_input.attachEvent) { _input.attachEvent('onbeforepaste', formatPasteDataToFloat); } else { _input.addEventListener('onbeforepaste', formatPasteDataToFloat, false); } }); function formatPasteDataToInteger() { clipboardData.setData('text', clipboardData.getData('text').replace(/[^\d]/g, '')); } function formatPasteDataToFloat() { clipboardData.setData('text', clipboardData.getData('text').replace(/[^0-9.]/g, '')); } }); <input type="text" class="integer"/> <input type="text" class="float"/> |
|
返回顶楼 | |
发表时间:2012-07-02
anlystar 写道 哪有这么麻烦
js版 <input type="text" onkeyup="value=value.replace(/[^0-9.]/g,'')" onbeforepaste="clipboardData.setData('text',clipboardData.getData('text').replace(/[^0-9.]/g,''))"/> jQuery版 $(function() { $('.integer').bind({ keyup : function() { $(this).val($(this).val().replace(/[^\d]/g, '')); } }); $('.integer').each(function() { var _input = $(this)[0]; if (_input.attachEvent) { _input.attachEvent('onbeforepaste', formatPasteDataToInteger); } else { _input.addEventListener('onbeforepaste', formatPasteDataToInteger, false); } }); $('.float').bind({ keyup : function() { $(this).val($(this).val().replace(/[^0-9.]/g, '')); } }); $('.float').each(function() { var _input = $(this)[0]; if (_input.attachEvent) { _input.attachEvent('onbeforepaste', formatPasteDataToFloat); } else { _input.addEventListener('onbeforepaste', formatPasteDataToFloat, false); } }); function formatPasteDataToInteger() { clipboardData.setData('text', clipboardData.getData('text').replace(/[^\d]/g, '')); } function formatPasteDataToFloat() { clipboardData.setData('text', clipboardData.getData('text').replace(/[^0-9.]/g, '')); } }); <input type="text" class="integer"/> <input type="text" class="float"/> 呵呵,只是方法不同而已。很早之前就像用兄弟这种正则表达式的判断了,无奈正则表达式很差劲啊,最近在学习呢 |
|
返回顶楼 | |
发表时间:2012-07-02
正则完全可以搜,主要还是思路上,具体的代码都可以google,思路不好google呀
|
|
返回顶楼 | |
发表时间:2012-07-02
anlystar 写道 正则完全可以搜,主要还是思路上,具体的代码都可以google,思路不好google呀
呵呵,当时很着急,所以就按照公司的以为JS高手的思路改了 |
|
返回顶楼 | |
发表时间:2012-07-05
你试试,你这个 如果是粘贴进去的呢?
|
|
返回顶楼 | |
发表时间:2012-07-05
anlystar 写道 你试试,你这个 如果是粘贴进去的呢?
汉字是粘贴不进去的吧? |
|
返回顶楼 | |
发表时间:2012-07-05
看着你哪个好像可以
|
|
返回顶楼 | |
发表时间:2012-07-05
anlystar 写道 看着你哪个好像可以
我试过了不行 |
|
返回顶楼 | |