字符串方法


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. Linux—系统管理

    查看Linux系统版本                                                                    CentOS系统 # centos7查看命 ...

  2. 多个git合并,并保留log历史记录

    面临的需求是:将多个git仓库作为一个单独目录,整合到一个新的git仓库中:并且保留历史记录. 1. 新建一个summary仓库 新建一个summary仓库,用于整合一系列git仓库. git clo ...

  3. LeetCode 1243 数组变换

    地址 https://leetcode-cn.com/contest/biweekly-contest-12/problems/array-transformation/ 首先,给你一个初始数组 ar ...

  4. WPF 精修篇 数据触发器

    原文:WPF 精修篇 数据触发器 数据触发器 可以使用Binding 来绑定控件 或者数据源 来触发相关动作 举栗子 <Window.Resources> <Style Target ...

  5. linux编程fcntl获取和设置文件状态

    #include <stdio.h> #include <stdlib.h> #include <unistd.h> #include <fcntl.h> ...

  6. pytorch固定部分参数

    pytorch固定部分参数 不用梯度 如果是Variable,则可以初始化时指定 j = Variable(torch.randn(5,5), requires_grad=True) 但是如果是m = ...

  7. Python自动群发邮件,只需20行代码!

    今日分享 Python自动群发邮件 import smtplib from email import (header) from email.mime import (text, applicatio ...

  8. 07-Django模板(1)

    模板介绍 作为web框架,Django提供了模板,用于编写html代码(嵌入模板代码,更快更方便的完成页面开发,在通过视图中渲染模板,将最终生成的页面返回给浏览器(客户端)).模板是关于外表的渲染的, ...

  9. 依赖注入组件 Autofac 的小记

    1.  批量给 Service 层自动注入.(支持 ASP.NET Core) builder.RegisterAssemblyTypes(typeof(IProductService).Assemb ...

  10. 错误InnoDB:Attemptedtoopenapreviouslyopenedtablespace.

    2013-08-04 13:48:22 760 [ERROR] InnoDB: Attempted to open a previously opened tablespace. Previous t ...