我使用解码URIComponent解码后,URL看起来像这样
https://secretStar.22.test.com/l/{"mode":"test","app":"revenue:app","param2":1,"loaded":{"APPLICATION@markup://revenue:app":"unique_identifier"},"pathPrefix":"","xx":1}/script22.js
现在,我想从此URL中提取一些细节,例如:
mode = test
app = revenue:app
param2 = 1
appMarkupRevenueApp = unique identifier
scriptName = script.js
如果这些值是qs参数,则可以使用qs参数提取它。我能够通过编写一个先进行拆分然后再拆分的函数来提取信息,但是从csv文件中的4k以上的URL中提取这些参数时,效率不是很高。
是否有更好的方法来提取这些?我可以想到正则表达式,但是我对此并不十分熟悉,因此无法正常工作。
答案 0 :(得分:2)
您可以通过匹配嵌入的JSON,然后将其转换为对象,也许使用类似这样的方法来实现:
JSON.parse(foo.match(/({.+})[^}]+/)[1])
正则表达式/({.+})[^}]+/
通过匹配{
后跟所有内容,然后匹配}
来创建一个组,然后仅在该组后跟非{ {1}}
JSON正在解析第一个匹配的组。
有一个问题,我不确定是由于您的问题有错字或与}
有关:
在预期的输出中,您具有:
decodeURIComponent
但是您的数据具有
appMarkupRevenueApp = unique identifier
这是很不匹配的,并且不明显是正确的
小型演示:
"APPLICATION@markup://revenue:app":"unique_identifier"