正则组成及简单应用

**元字符: **每一个正则表达式都是由元字符和修饰符组成的。
[元字符] -> 在//之间具有意义的一些字符。

具有特殊意义的元字符:
: 转义字符,转义后面字符所代表的含义。
^: 以某一个元字符开始。
$: 以某一个元字符结束。

    var reg = /^\d$/; // -> 只能是一个0-9之间的数字
    console.log(reg.test("9")); // -> true;
    console.log(reg.test("012")); // -> false

\n: 匹配一个换行符。
.: 除了\n以外的任意字符。

    var reg = /^0.2$/; // -> 以0开头,以2结尾,中间可以是除了\n的任意字符
    console.log(reg.test("0.2")); // -> true
    console.log(reg.test("0-2")); // -> true
    var reg = /^0\.2$/;
    console.log(reg.test("0.2")); // -> true
    console.log(reg.test("0-2")); // -> false

(): 分组 -> 把一个大正则本身划分成几个小的正则。

var reg = /^(\d+)derrick(\d+)$/;

分组的作用:
改变x|y的默认的优先级

    var reg = /^(18|19)$/; // 只能18或19了
    console.log(reg.test("18")); // true
    console.log(reg.test("19")); // true
    console.log(reg.test("189")); // false
    // 如果不使用分组:
    var reg = /^18|19$/;
    console.log(reg.test("18")); // true
    console.log(reg.test("19")); // true
    console.log(reg.test("189")); // true
    console.log(reg.test("119")); // true
    console.log(reg.test("181")); // true
    console.log(reg.test("1819")); // true
    console.log(reg.test("819")); // true
    console.log(reg.test("89")); // false

x|y: x或者y中的一个。
[xyz]: x或者y或者z中的一个。

在[]中出现的所有的字符都是代表本身意思的字符,没有特殊含义。

    var reg = /^[.]$/;
    console.log(reg.test(".")); // -> true
    console.log(reg.test("1")); // -> false

代表出现次数的量词元字符
*: 出现零到多次。
+: 出现一到多次。
?: 出现零次或者一次。
{n}: 出现n次。
{n,}: 出现n到多次。
{n, m}: 出现n到m次。

    var reg = /^\d+$/;
    console.log(reg.test("2015")); // -> true

    // 一个简单的验证手机号的正则: 11位数字,第一位是1
    var reg = /$1\d{10}$/;

应用
1. 有效数字正则: 正数、负数、零、小数

    // 12.3, 12, -12, +12, 0.2
    // 1) "." 可以出现也可以不出现,但是一旦出现,后面必须跟着一位或者多位数字
    // 2) 最开始可能有+或者-,也可以没有
    // 3) 整数部分,一位数可以是0-9之间的任意一个,多位数不能以数字0开头
    var reg = /^[+-]?(\d|([1-9]\d+))(\.\d+)?$/;

2. 年龄介于18-65之间: 18-19, 20-59, 60-65

    console.log(reg.test("18")); // true
    console.log(reg.test("21")); // true
    console.log(reg.test("38")); // true
    console.log(reg.test("91")); // false
    console.log(reg.test("126")); // false

3. 验证邮箱的正则(简版)

    // xxx@xxx.com
    // 左边部分: 数字、字母、下划线、.、-、
    var reg = /^[\w.-]+@[0-9a-zA-Z]+(\.[a-zA-Z]{2,4}){1,2}$/;

4. 中国标准真实姓名 2-4位数字

var reg = /^[\u4e00-\u9fa5]{2,4}$/;

5. 身份证号码

    // var reg = /^\d{17}(X|\d)$/;
    var reg = /^(\d{2})(\d{4})(\d{4})(\d{2})(\d{2})(\d)(\d|X)$/;
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,752评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,100评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,244评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,099评论 1 286
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,210评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,307评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,346评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,133评论 0 269
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,546评论 1 306
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,849评论 2 328
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,019评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,702评论 4 337
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,331评论 3 319
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,030评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,260评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,871评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,898评论 2 351

推荐阅读更多精彩内容