在javascript正则表达式中获取除匹配之外的所有内容
我使用以下正则表达式获取url后的第一部分:在javascript正则表达式中获取除匹配之外的所有内容,javascript,regex,string,url,replace,Javascript,Regex,String,Url,Replace,我使用以下正则表达式获取url后的第一部分: ^http[s]?:\/\/.*?\/([a-zA-Z-_.%]+).*$ 它与以下URL中的测试相匹配: foo.com 测试 测试/ 测试条形图 我现在要做的是重新创建相同的url,但用不同的值替换test。要么在比赛前和比赛后取零件,要么逆转结果 我确信有一种regexy方法可以做到这一点,但我无法找到如何做到这一点。您可以在/test之前为零件使用捕获组,并将其用作替换中的反向参考: var re = /^(https?:\/\/[^\/
^http[s]?:\/\/.*?\/([a-zA-Z-_.%]+).*$
它与以下URL中的测试相匹配:
foo.com测试
测试/
测试条形图 我现在要做的是重新创建相同的url,但用不同的值替换test。要么在比赛前和比赛后取零件,要么逆转结果
我确信有一种regexy方法可以做到这一点,但我无法找到如何做到这一点。您可以在
/test
之前为零件使用捕获组,并将其用作替换中的反向参考:
var re = /^(https?:\/\/[^\/]+\/)[^?\/]+/gmi;
var subst = '$1foobar';
var result = str.replace(re, subst);
[^?\/]+
将匹配URL中域名前面的文本。作为原始正则表达式,它还假设URL以http://
或https://
开头
您可以在
/test
之前为零件使用捕获组,并在替换时将其用作背面参考:
var re = /^(https?:\/\/[^\/]+\/)[^?\/]+/gmi;
var subst = '$1foobar';
var result = str.replace(re, subst);
[^?\/]+
将匹配URL中域名前面的文本。作为原始正则表达式,它还假设URL以http://
或https://
开头
你说的听起来不错,把捕获组放在它周围,就像这样
^(http[s]?:\/\/.\/.\/)[a-zA-Z-\.%+(.*)$
,替换为$1newtest$2
你说的不错,把捕获组放在它周围,就像这样^(http[s]?:\/\/\/.\/.\/.\/.\/)[a-zA-Z-.%+.+(.$$
,替换为$1newtest$2