javascript中expression的用法整理


Posted in Javascript onMay 13, 2014

小哥我最近在学习javaScript, 学到regular expression的时候见知识点有些杂乱,所以特别写篇博客做个总结。

定义

在javascript里定义reg exp有两种方法:

1) 用new exp : var exp1 = new exp("abc");

2) 直接在两个/中间放pattern: var exp2 = /abc/; //注意。。没有双引号哟, 加了就成string了

特殊字符

目测特殊字符和perl的是一样的。。直接拿来用就好

\d Digit characters
\w Alphanumeric characters (“word characters”)
\s Whitespace characters (space, tab, newline, and similar)
\D Characters that are not digits
\W Non-alphanumeric characters
\S Non-whitespace characters
. A period matches all characters except newlines
有个很简单的记的方法:

d = digit 所以是数字

w = word 所以是字母

s = space 所以是空格

所有大写全是反的。。

括号[]

在括号中放pattern 代表只要符合任意字符都为真。 (和java 或者 Perl都是一样一样的)

比如

console.log(/[01]/.test("023424")); // true console.log(/[01]/.test("13424")); // true 
console.log(/[01]/.test("23424")); // false

括号()

表示要符合括号里的全部才会为真

比如

console.log(/[01]/.test("013424")); // true console.log(/[01]/.test("13424")); // false 
console.log(/[01]/.test("230424")); // false 
console.log(/[01]/.test("230142401")); // true

Quantifiers

和java是一样一样一样的。。 这个表很好。。小哥我一直喜欢用

Greedy Reluctant Possessive Meaning
X? X?? X?+ X, once or not at all
X* X*? X*+ X, zero or more times
X+ X+? X++ X, one or more times
X{n} X{n}? X{n}+ X, exactly n times
X{n,} X{n,}? X{n,}+ X, at least n times
X{n,m} X{n,m}? X{n,m}+ X, at least n but not more thanm times

expression object functions

1) test 这个很简单,只用把要test的string放到test(...)里,这个function就会return true/false 代表 match/unmatch

2) exec, 这个function返还null如果没有找到match的string.. 如果找到了就会返还一个array. 这个里边包含按顺序match的string

3) String.replace(expression1, string1) 这个function把expression中match的部分换成string1, string1里可以用之前expression中的parenthesized group

,来替代其中的某个部分。 比如说"co-ol".replace(/[\w]+\-[\w]+/,"$2-$1"); //"ol-co" 一直可以用到$9

4)String.replace(expression, function) 这个是加强版,而且很强大, 可以通过function来定义任何你想要的output。具体用法不在这里一一列出,请参考

点击打开链接

动态生成reg expression
当你想要用在reg exp里的东西只有runtime才知道的时候,这个方法就可以适用
生成reg exp其实只需要用string 建好reg exp的样子, 再用Exp的constructor就可以。 (在文章开头的地方提到过)

例如:

var name = "dear" “oh, my dear”.replace(new Exp(name), "god"); // oh, my god

但是如果名字中有特殊字符可能会用在regular expression的时候, 往往上边的方法会出错。
所以, 在那种情况下,我们可以把input string的每一个字符的前边都加上反斜杠 比如:
var name = df[]vxv; 
var expName = name.replace("/[^/w/s]/g","\\$&"); 
"my name is df[]vxv".replace(new Exp(name), "Bob"); // my name is Bob
Javascript 相关文章推荐
javascript小数计算出现近似值的解决办法
Feb 06 Javascript
jQuery 学习6 操纵元素显示效果的函数
Feb 07 Javascript
jquery子元素过滤选择器使用示例
Jun 24 Javascript
JS Replace()的高级使用方法介绍
Jun 29 Javascript
JQuery Tips相关(1)----关于$.Ready()
Aug 14 Javascript
javascript实现数独解法
Mar 14 Javascript
JavaScript实现动画打开半透明提示层的方法
Apr 21 Javascript
浅谈JS原型对象和原型链
Mar 02 Javascript
AngularJS使用带属性值的ng-app指令实现自定义模块自动加载的方法
Jan 04 Javascript
vue-content-loader内容加载器的使用方法
Aug 05 Javascript
ES6 中可以提升幸福度的小功能
Aug 06 Javascript
利用JavaScript为句子加标题的3种方法示例
Jan 05 Javascript
JS函数重载的解决方案
May 13 #Javascript
一个JS函数搞定网页标题(title)闪动效果
May 13 #Javascript
JS获得浏览器版本和操作系统版本的例子
May 13 #Javascript
当滚动条滚动到页面底部自动加载增加内容的js代码
May 13 #Javascript
js语法学习之判断一个对象是否为数组
May 13 #Javascript
js中定义一个变量并判断其是否为空的方法
May 13 #Javascript
jQuery 计算iframe 窗口大小的方法
May 13 #Javascript
You might like
PHP 删除一个目录及目录下的所有文件的函数代码
2010/05/26 PHP
php批量删除数据库下指定前缀的表以prefix_为例
2014/08/24 PHP
php创建session的方法实例详解
2015/01/27 PHP
十大使用PHP框架的理由
2015/09/26 PHP
PHP基于单例模式编写PDO类的方法
2016/09/13 PHP
thinkPHP框架中执行原生SQL语句的方法
2017/10/25 PHP
正则表达式搭配js轻松处理json文本方便而老古
2013/02/17 Javascript
js禁止页面使用右键(简单示例代码)
2013/11/13 Javascript
怎么判断js脚本加载完成
2014/02/28 Javascript
jQuery淡入淡出元素让其效果更为生动
2014/09/01 Javascript
JavaScript替换当前页面的方法
2015/04/03 Javascript
轻松搞定jQuery.noConflict()
2016/02/15 Javascript
深入理解Angular2 模板语法
2016/08/07 Javascript
在Docker快速部署Node.js应用的详细步骤
2016/09/02 Javascript
Bootstrap标签页(Tab)插件使用方法
2017/03/21 Javascript
深入理解JavaScript 参数按值传递
2017/05/24 Javascript
JavaScript实现提交模式窗口后刷新父窗口数据的方法
2017/06/16 Javascript
nginx配置React静态页面的方法教程
2017/11/03 Javascript
React全家桶环境搭建过程详解
2018/05/18 Javascript
解决vue2.0 element-ui中el-upload的before-upload方法返回false时submit()不生效问题
2018/08/24 Javascript
微信小程序按钮去除边框线分享页面功能
2018/08/27 Javascript
解决axios会发送两次请求,有个OPTIONS请求的问题
2018/10/25 Javascript
Vue实现简易翻页效果源码分享
2018/11/08 Javascript
jQuery实现的模仿雨滴下落动画效果
2018/12/11 jQuery
vue中引入mxGraph的步骤详解
2019/05/17 Javascript
Python使用面向对象方式创建线程实现12306售票系统
2015/12/24 Python
python pandas时序处理相关功能详解
2019/07/03 Python
Python中的sys.stdout.write实现打印刷新功能
2020/02/21 Python
Airbnb爱彼迎官网:成为爱彼迎房东,赚取收入
2019/03/14 全球购物
Quiksilver美国官网:始于1969年的优质冲浪服和滑雪板外套
2020/04/20 全球购物
应用艺术专业个人的自我评价
2014/01/03 职场文书
基层领导干部“四风”问题批评与自我批评
2014/09/23 职场文书
测量员岗位职责
2015/02/14 职场文书
部门经理迟到检讨书
2015/02/16 职场文书
Python实现拼音转换
2021/06/07 Python
Python制作表白爱心合集
2022/01/22 Python