字符串方法


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. 测试IP的一些网址

    http://httpbin.org/ip http://ip111.cn http://test.abuyun.com https://www.whatismybrowser.com

  2. Less(5)

    考查点:双查询报错注入 1.先判断注入类型 (1)首先看到要求,要求传一个ID参数,并且要求是数字型的:?id=1 (2)再输入?id=1' 显示报错,报错多了一个单引号 (3)再输入?id=1'' ...

  3. AcWing 29. 删除链表中重复的节点

    题目地址 https://www.acwing.com/problem/content/description/27/ 来源:剑指Offer 题目描述在一个排序的链表中,存在重复的结点,请删除该链表中 ...

  4. Go 字符串 (string)

    字符串类型为 string,使用双引号或者反引号包起来 字符串形式 反引号 当使用反引号时不会对字符串进行转义,并可以包含多行文本 示例: package main import "fmt& ...

  5. WindowsOS下Nginx+PHP环境配置

    Nginx 配置虚拟主机 在conf目录中的nginx.conf中最后一行前面加上 include vhost/*.conf; 在conf目录中添加一个文件夹vhost(此文件夹用来保存Nginx虚拟 ...

  6. Mysql如何在删库后可以不用跑路

    我一直在想,地球上这么多程序员,应该有很多人在团队做项目的时候,出过很大的错误,比如说不小心删了库,活动福利字段多写了个零导致全服务器玩家领到数倍奖励,听了沙雕群友的话执行rm -rf命令. 记得有一 ...

  7. Luogu P3600 随机数生成器

    Luogu P3600 随机数生成器 题目描述 sol研发了一个神奇的随机数系统,可以自动按照环境噪音生成真·随机数. 现在sol打算生成\(n\)个\([1,x]\)的整数\(a_1...a_n\) ...

  8. poj-3682 King Arthur's Birthday Celebration

    C - King Arthur's Birthday Celebration POJ - 3682 King Arthur is an narcissist who intends to spare ...

  9. 前端之javascript2

    js组成和标签获取元素 javascript组成 1.ECMAscript javascript的语法(变量.函数.循环语句等语法)2.DOM 文档对象模型 操作html和css的方法(比如通过id或 ...

  10. TreeViewItem节点添加图标后再加header

    1.需要实现的效果如图 2.解决方案 1).给TreeViewItem中添加children,children为包含一个stackpanel,在stackpanel中包含Image和TextBlock ...