美文网首页
正则组成及简单应用

正则组成及简单应用

作者: 阿九是只大胖喵 | 来源:发表于2017-03-07 12:42 被阅读0次

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

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

    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)$/;

相关文章

网友评论

      本文标题:正则组成及简单应用

      本文链接:https://www.haomeiwen.com/subject/wpkmgttx.html