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面向对象编程代码
Dec 19 Javascript
JS判断文本框内容改变事件的简单实例
Mar 07 Javascript
JavaScript中的object转换函数toString()与valueOf()介绍
Dec 31 Javascript
jQuery学习笔记之2个小技巧
Jan 19 Javascript
JavaScript中数据结构与算法(五):经典KMP算法
Jun 19 Javascript
bootstrap weebox 支持ajax的模态弹出框
Feb 23 Javascript
基于jquery实现多选下拉列表
Aug 02 jQuery
详解为Bootstrap Modal添加拖拽的方法
Jan 05 Javascript
通过vue-router懒加载解决首次加载时资源过多导致的速度缓慢问题
Apr 08 Javascript
Vue中父子组件通讯之todolist组件功能开发
May 21 Javascript
Angular.JS读取数据库数据调用完整实例
Jul 02 Javascript
解决vue项目中某一页面不想引用公共组件app.vue的问题
Aug 14 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 strtotime函数详解
2009/12/18 PHP
PHP计划任务、定时执行任务的实现代码
2011/04/23 PHP
PHP防止表单重复提交的几种常用方法汇总
2014/08/19 PHP
在CentOS上搭建LAMP+vsftpd环境的简单指南
2015/08/01 PHP
thinkPHP3.2简单实现文件上传的方法
2016/05/16 PHP
Nginx下ThinkPHP5的配置方法详解
2017/08/01 PHP
可以文本显示的公告栏的js代码
2007/03/11 Javascript
修复IE9&safari 的sort方法
2011/10/21 Javascript
一个页面元素appendchild追加到另一个页面元素的问题
2013/01/27 Javascript
javascript:json数据的页面绑定示例代码
2014/01/26 Javascript
Jquery 实现图片轮换
2015/01/28 Javascript
数据分析软件之FineReport教程:[5]参数界面JS(全)
2015/08/13 Javascript
AngularJS 表达式详解及实例代码
2016/09/14 Javascript
关于JavaScript中事件绑定的方法总结
2016/10/26 Javascript
js设置文字颜色的方法示例
2016/12/30 Javascript
js判断手机号是否正确并返回的实现代码
2017/01/17 Javascript
webpack打包后直接访问页面图片路径错误的解决方法
2017/06/17 Javascript
Vue组件选项props实例详解
2017/08/18 Javascript
NodeJS 将文件夹按照存放路径变成一个对应的JSON的方法
2018/10/17 NodeJs
Javascript原生ajax请求代码实例
2020/02/20 Javascript
基于javascript canvas实现五子棋游戏
2020/07/08 Javascript
pytorch 自定义卷积核进行卷积操作方式
2019/12/30 Python
Python 识别12306图片验证码物品的实现示例
2020/01/20 Python
Spartoo比利时:欧洲时尚购物网站
2017/12/06 全球购物
韩国现代百货官网:Hmall
2018/03/21 全球购物
某科技软件测试面试题
2013/05/19 面试题
标准的毕业生自荐信
2014/04/20 职场文书
环境整治工作方案
2014/05/18 职场文书
小学清明节活动总结
2014/07/04 职场文书
小学阳光体育活动总结
2014/07/05 职场文书
企业领导对照检查材料
2014/08/20 职场文书
小学中队委竞选稿
2015/11/20 职场文书
使用Pytorch训练two-head网络的操作
2021/05/28 Python
MySQL的安装与配置详细教程
2021/06/26 MySQL
简单谈谈Python面向对象的相关知识
2021/06/28 Python
OpenCV绘制圆端矩形的示例代码
2021/08/30 Python