我的表单中有一个地址字段,我想限制
* | \ " : < > [ ] { } \ ( ) '' ; @ & $
我试过用
var nospecial=/^[^* | \ " : < > [ ] { } ` \ ( ) '' ; @ & $]+$/;
if(address.match(nospecial)){
alert('Special characters like * | \ " : < > [ ] { } ` \ ( ) \'\' ; @ & $ are not allowed');
return false;
但它不起作用。请告诉我我错过了什么?
答案 0 :(得分:6)
您需要转义字符类中的右括号(以及反斜杠)。您也不需要所有空格:
var nospecial=/^[^*|\":<>[\]{}`\\()';@&$]+$/;
我摆脱了你所有的空间;如果你想限制空格字符,请重新添加一个空格。
编辑正如@fab在评论中指出的那样,扭转正则表达式的意义会更有效:
var specials=/[*|\":<>[\]{}`\\()';@&$]/;
并测试是否存在特殊字符(而不是缺少一个字符):
if (specials.test(address)) { /* bad address */ }
答案 1 :(得分:0)
使用以下功能
function checkSpcialChar(event){
if(!((event.keyCode >= 65) && (event.keyCode <= 90) || (event.keyCode >= 97) && (event.keyCode <= 122) || (event.keyCode >= 48) && (event.keyCode <= 57))){
event.returnValue = false;
return;
}
event.returnValue = true;
}
答案 2 :(得分:0)
/ [$&+,:; =?[] @#| {}'<>。^ *()%!-/] /
下面的一个不允许输入这些字符,它将返回空格
.replace(/[$&+,:;=?[\]@#|{}'<>.^*()%!-/]/,"");