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

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

作者: 芗芗_ | 来源:发表于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)}↵")

相关文章

  • 正则表达式

    创建正则表达式 正则.test(字符串) 正则去匹配字符串,如果匹配成功就返回真,如果匹配失败就返回假 转义字符 ...

  • 正则表达式

    创建正则表达式 正则.test(字符串) 正则去匹配字符串,如果匹配成功就返回真,如果匹配失败就返回假 转义字符 ...

  • 正则表达式

    正则表达式主要用于字符串的查找、匹配、分割 match(正则表达式字符串,需要匹配的字符串) 1.不带任何正则符号...

  • Python基础(15)——正则表达式

    re.match() re.match(正则表达式,要匹配的字符串),匹配出以字符串的起始位置开始匹配正则表达式,...

  • 提取匹配内容

    正则表达式匹配字符串并提取正则匹配的内容 this.([a-zA-z]+) = 1 代表第一个括号内匹配的字符串

  • 正则位置匹配

    正则表达式要么匹配字符,要么匹配位置。 一、字符串的位置 二、正则表达式如何匹配位置 1、es5中匹配位置的正则:...

  • Python之路13:

    re 模块,正则匹配表达式 正则匹配表达式就是字符串的匹配规则 re 模块的匹配语法: re.match 从头开始...

  • 正则下

    一、字符串方法(匹配正则)match() 返回匹配字符串的结果,返回为数组内容或nullsearch() ...

  • 正则表达式、ES6 中的表达式的新特性

    正则表达式用于对字符串模式匹配及检索替换,是对字符串执行模式匹配的强大工具。 一、正则表达式 1、定义正则(语法)...

  • 匹配html文本中style、link、script的正则表达式

    对于一段html文本字符串,如下,如何匹配出其中的资源: 匹配正则表达式写法。 其中脚本匹配需要正则,无法匹配内容...

网友评论

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

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