• JavaScript从入门到精通系列第三十一篇:详解JavaScript中的字符串和正则表达式相关的方法


     

    文章目录

    知识回顾

    1:概念回顾

    2:正则表达式字面量

    一:字符串中正则表达式方法

    1:split

    2:search

    3:match

    4:replace


    知识回顾

    1:概念回顾

            正则表达式用于定义一些字符串的规则,计算机可以根据正则表达式检查一个字符串是否符合规则,或者将字符串中符合规则的内容提取出来。

    2:正则表达式字面量

            语法:var 变量 =/正则表达式/匹配模式;这种方式创建更加简单,使用构造函数创建更加灵活

    var reg = new RegExp("正则表达式","匹配模式");

            正则表达式的预发是基于构造函数创建,里边需要有两个参数,一个是正则表达式,另外一个是匹配模式。

            编写代码:

    1. var reg = new RegExp("a");
    2. console.log(a);

    一:字符串中正则表达式方法

    1:split

            split是String当中的方法,可以将一个字符串拆分为一个数组

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.split("c");
    3. console.log(result);

            但是这样玩有点不灵活,写啥按照啥进行拆分。 我们想根据我们任意字母来将字符串进行拆分

            我们方法中可以传递一个正则表达式作为一个参数,这样方法将会按照正则表达式去拆分字符串。

            证明这件事情:

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.split(/[a-z]/);
    3. console.log(result);

            运行结果: 

    2:search

            这个方法可以搜索字符串中是否指定内容

            证明这件事情:

    1. var str = "hello abc hello abc";
    2. var result = str.search("abc");
    3. console.log(result);

            运行结果:

            返回第一次搜索到的结果索引如果没有的话返回-1 

            他可以接收一个正则表达式作为参数,根据正则表达式作进行检索。

            证明这件事情:

            搜索我们字符串中是否包含:abc 或者 aec 或者 afc

    1. var str = "hello abc hello aec afc";
    2. var result = str.search(/a[bef]c/);
    3. console.log(result);

            运行结果:

    3:match

            可以根据正则表达式将复合条件的内容提取出来

            证明这件事情:

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.match(/[a-z]/);
    3. console.log(result);

            运行结果:

            计算机比较懒,只找了第一个,我们需要告诉计算机,我们要所有的复合条件的内容,我们需要设置正则表达式进行全局匹配模式。 

            证明这件事情:

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.match(/[a-z]/g);
    3. console.log(result);

            运行结果:

            再设置忽略大小写:

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.match(/[a-z]/gi);
    3. console.log(result);

             运行结果:

            可以为一个正则表达式设置多个匹配模式且顺序无所谓。 

            这种情况返回的数据是一个数组。

    4:replace

            可以将字符串中的指定内容替换为新的内容

            证明这件事情:

    1. var str = "1a2b3c4d5e6f";
    2. var result = str.replace(/[a-z]/gi,"@_@");
    3. console.log(result);

            指的注意的是split这个方法不论是写不写g都会进行全局匹配 

  • 相关阅读:
    【读书笔记】《0day安全》第二章:栈溢出的原理和实践
    react|redux状态管理
    创建一个react项目 create-next-app
    Service详解
    .Net8 AddKeyedScoped键值key注册服务异常
    Apache JMeter 安装教程
    基于数组实现栈,再基于栈实现后缀表达式计算
    基于MiniTest的小程序自动化测试
    冰点还原精灵DeepFreeze重启后图标不见了
    asp毕业设计——基于asp+access的网上远程教育网设计与实现(毕业论文+程序源码)——网上远程教育网
  • 原文地址:https://blog.csdn.net/Facial_Mask/article/details/134301134