<div class="jb51code">
<pre class="brush:js;">
<span style="font-family: Arial,Helvetica,sans-serif; background-color: rgb(255,255,255);">昨天项目搜索的时候报错,蛋疼的是生产库中的,看了下日志,原因是用户搜索的时候输入了特殊字符,没办法最快捷的办法是直接把用户输入的数据进行筛选,去掉特殊字符
<div class="jb51code">
<pre class="brush:js;">
<span style="font-family: Arial,Helvetica,sans-serif; background-color: rgb(255,255,255);">昨天项目搜索的时候报错,蛋疼的是生产库中的,看了下日志,原因是用户搜索的时候输入了特殊字符,没办法最快捷的办法是直接把用户输入的数据进行筛选,去掉特殊字符
有些特殊字符传入到后台是会产生错误的 有可能会sql注入,所以从根本上拦截
使用:在input控件上加入事件 根本没反应
这个好像有点小问题 中文状态下没反应 不知道怎么回事 所以又找了一种
var s = textBox.value.charAt(index);
if (IllegalString.indexOf(s) >= 0) {
s = textBoxvalue.substring(0,index);
textBox.value = s;
}
}
使用: onkeyup = "ValidateValue(this)" 他会输入以后会立马消失,用户是可以看得到我输入的 只是说输入以后就没了,弊端是连续输入就不会消失了(按住不动)
接下来最牛逼的一种 中和以上方式
这种方式用户可以看到输入了会立马消失 跟方式三差不多 但连续输入是有效的
一、document.onkeypress事件是当输入一个字符的时候就进行校验,校验时执行函授showKeyPress,返回true的时候可输入,false不可输入。
二、evt = (evt) ? evt : window.event,是按下键盘就产生此事件获得你键入的值(是键盘的keyCode)。
var realkey = String.fromCharCode(keyCode); String.fromCharCode()方法是把键盘值(keyCode)转换成你真实输入的值。
三、方法specialKey.indexOf(realkey):
.indexOf()是String的方法,字符串的IndexOf()方法搜索在该字符串上是否出现了作为参数传递的字符串,如果找到字符串,则返回字符的起始位置 (0表示第一个字符,1表示第二个字符依此类推)如果说没有找到则返回 -1
四、var specialKey = "#$%\^*\'\"\+";
这里是带转义符的字符串,#、$、%、^、*、'、"、+ 这些符号是特殊符号,其中前面带\的是需要转义的。
如果要在当个文本框中加限制输入特殊符号,用
以上所述是小编给大家介绍的input 禁止输入特殊字符的四种实现方式。编程之家 jb51.cc 收集整理的教程希望能对你有所帮助,如果觉得编程之家不错,可分享给好友!感谢支持。
原文链接:https://www.f2er.com/js/46341.html