zoukankan      html  css  js  c++  java
  • 字符串处理常见函数

    match方法

    定义和用法

    match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。

    该方法类似 indexOf() 和 lastIndexOf(),但是它返回指定的值,而不是字符串的位置。

    语法

    stringObject.match(searchvalue)
    stringObject.match(regexp)
    
    参数描述
    searchvalue 必需。规定要检索的字符串值。
    regexp 必需。规定要匹配的模式的 RegExp 对象。如果该参数不是 RegExp 对象,则需要首先把它传递给 RegExp 构造函数,将其转换为 RegExp 对象。

    返回值

    存放匹配结果的数组。该数组的内容依赖于 regexp 是否具有全局标志 g。

    说明

    match() 方法将检索字符串 stringObject,以找到一个或多个与 regexp 匹配的文本。这个方法的行为在很大程度上有赖于 regexp 是否具有标志 g。

    如果 regexp 没有标志 g,那么 match() 方法就只能在 stringObject 中执行一次匹配。如果没有找到任何匹配的文本, match() 将返回 null。否则,它将返回一个数组,其中存放了与它找到的匹配文本有关的信息。该数组的第 0 个元素存放的是匹配文本,而其余的元素存放的是与正则表达式的子表达式匹配的文本。除了这些常规的数组元素之外,返回的数组还含有两个对象属性。index 属性声明的是匹配文本的起始字符在 stringObject 中的位置,input 属性声明的是对 stringObject 的引用。

    如果 regexp 具有标志 g,则 match() 方法将执行全局检索,找到 stringObject 中的所有匹配子字符串。若没有找到任何匹配的子串,则返回 null。如果找到了一个或多个匹配子串,则返回一个数组。不过全局匹配返回的数组的内容与前者大不相同,它的数组元素中存放的是 stringObject 中所有的匹配子串,而且也没有 index 属性或 input 属性。

    注意:在全局检索模式下,match() 即不提供与子表达式匹配的文本的信息,也不声明每个匹配子串的位置。如果您需要这些全局检索的信息,可以使用 RegExp.exec()

           var str = "i am a good boy";
                var re = /boy/i;
                var r = str.match(re)
                var s = str.match('boy') //如果不包含结果,则返回null
                var v = str.match('good') 
                console.log(r) //["boy", index: 12, input: "i am a good boy"]
                console.log(s) //["boy", index: 12, input: "i am a good boy"]
                console.log(v) //["good", index: 7, input: "i am a good boy"]
                
                var str="1 plus 2 equal 3";
                console.log(str.match(/d+/g))//["1", "2", "3"]
                console.log(str.match(/d/g))//["1", "2", "3"]
                console.log(str.match(/[a-z]+/g))//["plus", "equal"]
                console.log(str.match(/[a-z]/g))//["p", "l", "u", "s", "e", "q", "u", "a", "l"]

    test方法

    定义和用法

     test()方法用于检测一个字符串是否匹配某个模式

    语法

    RegExpObject.test(string)
    参数描述
    string 必需。要检测的字符串。

    返回值

    如果字符串 string 中含有与 RegExpObject 匹配的文本,则返回 true,否则返回 false。

    说明

    调用 RegExp 对象 r 的 test() 方法,并为它传递字符串 s,与这个表示式是等价的:(r.exec(s) != null)。

           var str = "visit w3cschool";
                var patt1 = new RegExp('w3cschool')
                var patt2 = new RegExp('W3cschool')
                var patt3 = new RegExp('W3cschool','i')
                console.log(patt1.test(str))//true
                console.log(patt2.test(str))//false
                console.log(patt3.test(str))//true

    replace方法

    定义和用法

    replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

    语法

    stringObject.replace(regexp/substr,replacement)
    参数描述
    regexp/substr

    必需。规定子字符串或要替换的模式的 RegExp 对象。

    请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp 对象。

    replacement 必需。一个字符串值。规定了替换文本或生成替换文本的函数。

    返回值

    一个新的字符串,是用 replacement 替换了 regexp 的第一次匹配或所有匹配之后得到的。

    说明

    字符串 stringObject 的 replace() 方法执行的是查找并替换的操作。它将在 stringObject 中查找与 regexp 相匹配的子字符串,然后用 replacement 来替换这些子串。如果 regexp 具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。

    replacement 可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。但是 replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。

    字符替换文本
    $1、$2、...、$99 与 regexp 中的第 1 到第 99 个子表达式相匹配的文本。
    $& 与 regexp 相匹配的子串。
    $` 位于匹配子串左侧的文本。
    $' 位于匹配子串右侧的文本。
    $$ 直接量符号。

    注意:ECMAScript v3 规定,replace() 方法的参数 replacement 可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用。该函数的第一个参数是匹配模式的字符串。接下来的参数是与模式中的子表达式匹配的字符串,可以有 0 个或多个这样的参数。接下来的参数是一个整数,声明了匹配在 stringObject 中出现的位置。最后一个参数是 stringObject 本身。

     

    var str = "visit Microsoft!";
    console.log(str.replace(/Microsoft/,'W3Scholl'))//visit W3Scholl!
    var str = "visit Microsoft1,Microsoft2,Microsoft3,Microsoft4";
    console.log(str.replace(/Microsoft+d/g,'W3Scholl'))//visit W3Scholl,W3Scholl,W3Scholl,W3Scholl

    search()

    定义和用法

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

    语法

    stringObject.search(regexp)
    参数描述
    regexp

    该参数可以是需要在 stringObject 中检索的子串,也可以是需要检索的 RegExp 对象。

    注释:要执行忽略大小写的检索,请追加标志 i。

    返回值

    stringObject 中第一个与 regexp 相匹配的子串的起始位置。

    注释:如果没有找到任何匹配的子串,则返回 -1。

    说明

    search() 方法不执行全局匹配,它将忽略标志 g。它同时忽略 regexp 的 lastIndex 属性,并且总是从字符串的开始进行检索,这意味着它总是返回 stringObject 的第一个匹配的位置。

    var str="Visit W3School!";
    console.log(str.search(/W3School/))//6
    console.log(str.search(/w3School/))//-1 大小写敏感 不区分是否全局(g) console.log(str.search(/w3School/i))//6

    exec() 方法

    定义和用法

    exec() 方法用于检索字符串中的正则表达式的匹配。

    语法

    RegExpObject.exec(string)
    参数描述
    string 必需。要检索的字符串。

    返回值

    返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。

    说明

    exec() 方法的功能非常强大,它是一个通用的方法,而且使用起来也比 test() 方法以及支持正则表达式的 String 对象的方法更为复杂。

    如果 exec() 找到了匹配的文本,则返回一个结果数组。否则,返回 null。此数组的第 0 个元素是与正则表达式相匹配的文本,第 1 个元素是与 RegExpObject 的第 1 个子表达式相匹配的文本(如果有的话),第 2 个元素是与 RegExpObject 的第 2 个子表达式相匹配的文本(如果有的话),以此类推。除了数组元素和 length 属性之外,exec() 方法还返回两个属性。index 属性声明的是匹配文本的第一个字符的位置。input 属性则存放的是被检索的字符串 string。我们可以看得出,在调用非全局的 RegExp 对象的 exec() 方法时,返回的数组与调用方法 String.match() 返回的数组是相同的。

    但是,当 RegExpObject 是一个全局正则表达式时,exec() 的行为就稍微复杂一些。它会在 RegExpObject 的 lastIndex 属性指定的字符处开始检索字符串 string。当 exec() 找到了与表达式相匹配的文本时,在匹配后,它将把 RegExpObject 的 lastIndex 属性设置为匹配文本的最后一个字符的下一个位置。这就是说,您可以通过反复调用 exec() 方法来遍历字符串中的所有匹配文本。当 exec() 再也找不到匹配的文本时,它将返回 null,并把 lastIndex 属性重置为 0。

    提示和注释

    重要事项:如果在一个字符串中完成了一次模式匹配之后要开始检索新的字符串,就必须手动地把 lastIndex 属性重置为 0。

    提示:请注意,无论 RegExpObject 是否是全局模式,exec() 都会把完整的细节添加到它返回的数组中。这就是 exec() 与 String.match() 的不同之处,后者在全局模式下返回的信息要少得多。因此我们可以这么说,在循环中反复地调用 exec() 方法是唯一一种获得全局模式的完整模式匹配信息的方法。

     

    var str  = "Visit W3School"; 
    var str1 = "Visit w3School"; 
    var patt = new RegExp("W3School","g"); var patt1 = new RegExp("W3School","gi"); console.log(patt.exec(str))//["W3School", index: 6, input: "Visit W3School"] console.log(patt1.exec(str1))//["W3School", index: 6, input: "Visit W3School"]

    compile()

    compile() 方法用于改变 RegExp。

    compile() 既可以改变检索模式,也可以添加或删除第二个参数。

    var patt1=new RegExp("e");
    console.log(patt1.test(
    "The best things in life are free")); //true patt1.compile("d"); console.log(patt1.test("The best things in life are free")); //false

     

     

     

     

     

     

     

     

  • 相关阅读:
    Javascript文件加载:LABjs和RequireJS
    【译】前端开发者的基本要求
    正则基础之——NFA引擎匹配原理
    JavaScript 设计模式 安全沙箱模式
    jsdoc_toolkit
    JS判断手机浏览器
    JavaScript:Object.prototype.toString方法的原理
    FullCalendar 官方文档翻译2
    浏览器缓存机制
    jQuery.extend 函数详解
  • 原文地址:https://www.cnblogs.com/xumqfaith/p/8521262.html
Copyright © 2011-2022 走看看