JS正则表达式匹配中文的问题

<!DOCTYPE html>
<html>
<head>
    <meta http-equiv="content-type" content="text/html; charset=UTF-8" />
    <script>
        var result = (new RegExp("/^[\u4e00-\u9fa5]$/")).test("所");
        console.log(result);
    </script>
</head>
<body>
</body>
</html>

为什么输出的是false?文件用vim :set fileencoding 确认是用UTF-8编码的

阅读 52.9k
7 个回答

var result = (new RegExp("^[\\u4e00-\\u9fa5]$")).test("所");
console.log(result);

跟 vim 没关系,本来结果就是 false,在 console 里打印一下 new RegExp("/^[\u4e00-\u9fa5]$/") 就知道了。

var result = (new RegExp("^[\\u4e00-\\u9fa5]$")).test("所");

或者

var result = /^[\u4e00-\u9fa5]$/.test("所");

js里 // 是正则表达式字面量,new RegExp创建后面参数带的是正则的string,题主把概念搞混了

找了一圈只匹配中文的正则都不对呢?最后我还是这样来判断了:

'要校验的字符串'.replace(/[\u4e00-\u9fa5]/g,'').length == 0

/[\u4E00-\u9FA5\uF900-\uFA2D]/.test(value);
其实上面好多不好使用!!试试这个

新手上路,请多包涵

我也正好碰到这个问题了
/[\u4E00-\u9FA5\uF900-\uFA2D]/.test(value);也不ok呢

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题