美文网首页
正则匹配字符串的背景图片

正则匹配字符串的背景图片

作者: 芗芗_ | 来源:发表于2019-01-23 12:12 被阅读0次

    最近有一个需求,匹配字符串里面的背景图片,并放到一个数组里面。
    第一个想到的就是正则的子表达式

    match() 方法可在字符串内检索指定的值,或找到一个或多个正则表达式的匹配。
    注意⚠️:在全局检索模式下,match() 即不提供与子表达式匹配的文本的信息,
    也不声明每个匹配子串的位置。如果您需要这些全局检索的信息,可以使用

    exec() 返回一个数组,其中存放匹配的结果。如果未找到匹配,则返回值为 null。
    exec() 方法的功能非常强大,它是一个通用的方法,而且使用起来也比 test() 方法以及支持正则表达式的 String 对象的方法更为复杂。

    除了数组元素和 length 属性之外,exec() 方法还返回两个属性。index 属性声明的是匹配文本的第一个字符的位置。input 属性则存放的是被检索的字符串 string。我们可以看得出,在调用非全局的 RegExp 对象的 exec() 方法时,返回的数组与调用方法 String.match() 返回的数组是相同的。

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

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

    所以还是要仔细的看文档。

    getImgSrc = (str)=>{
      var exec3 = /url\((.*?)\)+/g;
       var i = '' ;
       var arr = [];
        while(i !== null){
        var i = exec3.exec(str)
        i!==null && arr.push(i[1])
       
        }
    
        return arr
    }
    
    getImgSrc(".ssd-module-wrap .M15433045377941{height:789px; background-size:100% 100%; width:750px; background-color:#e9e9e9; background-image:url(//img30.360buyimg.com/sku/jfs/t26641/137/2291210125/205458/d568ad6b/5bfcf56dNf78c1e6b.jpg)}↵.ssd-module-wrap .M15433045697832{height:846px; background-size:100% 100%; width:750px; background-color:#d7d7d7; background-image:url(//img30.360buyimg.com/sku/jfs/t29149/65/750523973/162340/a6767867/5bfcf56dN512cf3bb.jpg)}↵.ssd-module-wrap .M15433045832683{height:567px; background-size:100% 100%; width:750px; background-color:#f2f2f2; background-image:url(//img30.360buyimg.com/sku/jfs/t29695/241/755921147/296506/9be99d1d/5bfcf56dN1027b77e.jpg)}↵")
    

    相关文章

      网友评论

          本文标题:正则匹配字符串的背景图片

          本文链接:https://www.haomeiwen.com/subject/ikkbgttx.html