字符串方法


search(reg)

  1. search()用于检索字符串中指定的子字符串,或检索与正则表达式相匹配的子字符串

  2. 方法返回第一个匹配结果index,查找不到返回-1

  3. search()不执行全局匹配,他将忽略标志g,并且总是从字符串的开始进行检索

例:
a1b1c1d1.search('1') // 1 a1b1c1d1.search(1) // 1 a1b1c1d1.search('10') // -1

match(reg)

  1. match()将检索字符串,以找到一个或多个与RegExp相匹配的文本
  2. RegExp是否具有标志g对结果影响很大

非全局调用 

  1. 如果RegExp没有标志g,那么match()方法就只能在字符串中执行一次匹配
  2. 如果没有找到任何匹配的文本,将返回null

  3. 否则它将返回一个数组,其中存放了与它找到的匹配文本有关的信息

返回数组的第一个元素是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本

除了常规的数组元素之外,返回的数组还含有两个对象属性

'index'声明匹配的文本的起始字符在字符串中的位置

'input'声明对'stringObject'的引用

-------------------------------------------------------------------------------------------------------------------------------------------------------------------

全局调用

如果RegExp具有标志g,那么match()方法将执行全局检索,找到字符串中的所有匹配的子字符串

没有找到任何匹配的子串,则返回null

如果找到了一个或多个匹配子串,则返回一个数组

数组元素中存放的是字符串中所有的匹配子串,而且也没有index属性或input属性

var reg3 = /\d(\w)\d/;

var reg4 = /\d(\w)\d/g;

var ts = '$1a2b3c4d5e';

var ret = ts.match(reg3);

console.log(ret);                                           // ["1a2","a"]

console.log(ret.index + '\t' + reg3.lastIndex);        // "1 0"    非全局调用lastIndex不生效

var ret = ts.match(reg4);

console.log(ret);                                           // ["1a2","3c4"]

console.log(ret.index + '\t' + reg4.lastIndex);             // "undefined 0"

split()

  1. 我们经常用split方法把字符串分割为字符数组 'abcd'.split(','); // ["a","b","c","d"]

  2. 在一些复杂的分割情况下我们可以使用正则表达式解决'a1b2c3d'.split(/\d/); // ["a","b","c","d"]

String.prototype.replace

  1. String.prototype.replace(str,replaceStr)

    例:
    "a1b".replace('1',2) "a2b"
  2. String.prototype.replace(reg,replaceStr)

    例:
    "a1b1c1".replace(/1/,2) "a2b1c1" 例:"a1b1c1".replace(/1/g,2) "a2b2c2"
  3. String.prototype.replace(reg,function)

    function会在每次匹配替换的时候调用,有四个参数
    
    1、匹配字符串
    
    2、正则表达式分组内容,没有分组则没有该参数</li>
    
    3、匹配项在该字符串中的index</li>
    
    4、原字符串</li>

    例:'a1b2c3d4e5' --------  'a2b3c4d5e6'
    
    'a1b2c3d4e5'.replace(/\d/g,function(match,index,origin){
    
            console.log(index);                   // 1   3    5   7  9
    
            return parenInt(match) + 1;             // 'a2b3c4d5e6'
    
    });
    例:'a1b2c3d4e5' --------   'a12c34e5'
    
    'a1b2c3d4e5'.replace(/(\d)(\w)(\d)/g,function(match,group1,group2,group3,index,origin){
    
        console.log(match);                     // "1b2"   "3d4"
    
        return group1 + group3;                 // 'a12c34e5'
    
    });

整理自慕课网教学 点此进入

初学JavaScript正则表达式(十三)的更多相关文章

  1. 初学JavaScript正则表达式(八)

    JavaScript正则贪婪模式与非贪婪模式 贪婪模式: 例: \d{3,6} 匹配数字3到6次(正则表达式默认为贪婪模式,即匹配最多次,失败即停) '12345678'.replace(/\d{3, ...

  2. 初学JavaScript正则表达式(十二)

    text / exec方法 text() var reg1 = /\w/; var reg2 = /\w/g; reg1.test('a') === true reg2.test('a') === t ...

  3. 初学JavaScript正则表达式(十一)

    JavaScript的对象属性 整理自慕课网教学 点此进入

  4. 初学JavaScript正则表达式(六)

    JavaScript预定义类 ab+数字+任意字符 ab[0-9][^\r\n] 等价于 ab\d. '@123@abc@'.replace(/@./g,'Q') Q23Qbc@ 将"@加任 ...

  5. 初学JavaScript正则表达式(四)

    字符类 [] 一般情况下正则表达式中一个字符对应字符串一个字符 可以使用元字符 [ ] 来构建一个简单的类        类泛指符合某些特征的对象 例: 'a1b1c1d1'.replace(/[ab ...

  6. 初学JavaScript正则表达式(三)

    正则表达式由两种基本的字符类型组成 原义文本字符 //a abc 1 元字符 元字符是有特使含义的非字母字符 * 匹配前面的子表达式零次或多次 + 匹配前面的子表达式一次或多次 ? 匹配前面的子表达式 ...

  7. 初学JavaScript正则表达式(二)

    正则表达式的实例化与标识符 字面量: var reg = /\bis\b/g // \b--字符边界 g全文搜索 查找单词为is的字符 He is a boy. IS He? 构造函数: var re ...

  8. 初学JavaScript正则表达式(十)

    前瞻与后顾 断言 === assert 符合断言为正向,不符合为负向 例 'a2*3'.replace(/\w(?=\d)/g,'x') ------- x2*3 看看'\d'前面是不是'\w',如果 ...

  9. 初学JavaScript正则表达式(九)

    分组:可以用 ( ) 来进行分组 一.Byron重复三次             Byron{3} --------- Byronnn 只是将紧挨着量词的字符重复            (Byron) ...

随机推荐

  1. USB HOST与 USB OTG的区别及工作原理

    在SmartQ 7上面,同时存在USB HOST与 USB OTG两个接口,我想问一下,这两个接口有什么区别么?我怎么认为HOST属于是多余呢? 麻烦高手解答,感激不尽!!! 转自USB HOST与 ...

  2. Linux自动同步时间

    一.安装时间同步工具 yum -y install ntp 二.同步时间 1.修改时区 cp -y /usr/share/zoneinfo/Asia/Shanghai /etc/localtime v ...

  3. [apue] syslog 导致 accept 出错?

    前几天在看apue第16章关于socket的例子,就是一个非常典型的socket服务器,关键代码如下: void serve (int sockfd) { int ret; int clfd; int ...

  4. 对比keep-alive路由缓存设置的2种方式

    方式有两种 .路由元信息(2.1.0版本之前) .属性方式(2.1.0版本之后新增) Vue2.1.0之前: 想实现类似的操作,你可以: 配置一下路由元信息 创建两个keep-alive标签 使用v- ...

  5. 201871010105-曹玉中《面向对象程序设计(Java)》第一周学习总结

    201871010105-曹玉中<面向对象程序设计(Java)>第一周学习总结 项目 内容 这个作业属于哪个课程 https://www.cnblogs.com/nwnu-daizh/ 这 ...

  6. JMeter基础知识系列一

    1.Jmeter简介: Apache Jmeter可以用于对静态和动态的资源(文件.web动态语言-PHP.java.ASP.net.java对象.数据库和查询.FTP服务器等)的性能进行测试.最初用 ...

  7. css3中calc、vw、vh、vmin、vmax 属性的应用及兼容性详解

    一. calc()的使用什么是calc()? calc()从字面我们可以把他理解为一个函数function.其实calc是英文单词calculate(计算)的缩写,是css3的一个新增的功能,用来指定 ...

  8. Codeforces Round #602 (Div. 2, based on Technocup 2020 Elimination Round 3) C. Messy 构造

    C. Messy You are fed up with your messy room, so you decided to clean it up. Your room is a bracket ...

  9. 使用OC实现单链表:创建、删除、插入、查询、遍历、反转、合并、判断相交、求成环入口

    一.概念 链表和数组都是一种线性结构,数组有序存储的,链表是无序存储的. 数组中的每一个元素地址是递增或者递减的关系,链表的每一个节点的地址没有此规律,它们是通过指针的指向连接起来. 链表种类:单链表 ...

  10. numpy的一点学习

    1.Numpy模块 NumPy是Python中的一个运算速度非常快的一个数学库,它非常重视数组.它允许你在Python中进行向量和矩阵计算,并且由于许多底层函数实际上是用C编写的,因此你可以体验在原生 ...