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 相关文章推荐
jquery的ajax从纯真网(cz88.net)获取IP地址对应地区名
Dec 02 Javascript
js实现网站首页图片滚动显示
Feb 04 Javascript
本地图片预览(支持IE6/IE7/IE8/Firefox3)经验总结
Mar 25 Javascript
jQuery中before()方法用法实例
Dec 25 Javascript
jQuery 限制输入字符串长度
Jun 20 Javascript
jquery选择器中的空格与大于号>、加号+与波浪号~的区别介绍
Jun 24 Javascript
AngularJS基础 ng-src 指令简单示例
Aug 03 Javascript
javascript实现简易计算器
Feb 01 Javascript
Node.js中使用mongoose操作mongodb数据库的方法
Sep 12 Javascript
bootstrap table列和表头对不齐的解决方法
Jul 19 Javascript
JavaScript实现简单的计算器
Jan 16 Javascript
v-slot和slot、slot-scope之间相互替换实例
Sep 04 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
自己做矿石收音机
2021/03/02 无线电
解析php addslashes()与addclashes()函数的区别和比较
2013/06/24 PHP
php中如何判断一个网页请求是ajax请求还是普通请求
2013/08/10 PHP
CI框架中集成CKEditor编辑器的教程
2014/06/09 PHP
php实现文件预览功能
2017/05/23 PHP
基于jquery的jqDnR拖拽溢出的修改
2011/02/12 Javascript
JS控制文本框textarea输入字数限制的方法
2013/06/17 Javascript
JS实现图片产生波纹一样flash效果的方法
2015/02/27 Javascript
简介JavaScript中的italics()方法的使用
2015/06/08 Javascript
jquery编写Tab选项卡滚动导航切换特效
2020/07/17 Javascript
jquery实现网页定位导航
2016/08/23 Javascript
BootstrapValidator实现注册校验和登录错误提示效果
2017/03/10 Javascript
利用Vue v-model实现一个自定义的表单组件
2017/04/27 Javascript
js绑定事件和解绑事件
2017/04/27 Javascript
easyui combogrid实现本地模糊搜索过滤多列
2017/05/13 Javascript
jQuery实现的文字逐行向上间歇滚动效果示例
2017/09/06 jQuery
vue-cli脚手架build目录下utils.js工具配置文件详解
2018/09/14 Javascript
详解webpack loader和plugin编写
2018/10/12 Javascript
实例详解带参数的 npm script
2019/05/28 Javascript
vue 组件中使用 transition 和 transition-group实现过渡动画
2019/07/09 Javascript
vue实现点击按钮“查看详情”弹窗展示详情列表操作
2020/09/09 Javascript
[06:53]2018DOTA2国际邀请赛寻真——勇于创新的Vici Gaming
2018/08/14 DOTA
python实现杨辉三角思路
2017/07/14 Python
Python爬虫框架scrapy实现的文件下载功能示例
2018/08/04 Python
Django REST framwork的权限验证实例
2020/04/02 Python
Python无头爬虫下载文件的实现
2020/04/02 Python
tensorflow从ckpt和从.pb文件读取变量的值方式
2020/05/26 Python
基于python 将列表作为参数传入函数时的测试与理解
2020/06/05 Python
Python3中FuzzyWuzzy库实例用法
2020/11/18 Python
大学生毕业自我鉴定范文
2013/09/19 职场文书
网上书店创业计划书
2014/01/12 职场文书
业绩考核岗位职责
2014/02/01 职场文书
2014年元旦联欢会活动策划方案
2014/02/16 职场文书
承诺书范文
2014/06/03 职场文书
小学优秀班主任材料
2014/12/17 职场文书
MySQL中distinct与group by之间的性能进行比较
2021/05/26 MySQL