[英]Regex Extract matched string from URL (working, better solution?)
所以我基本上我想测试一个url匹配一个域,然后返回(如果它存在)最后一次出现a(划线分隔)组w 4-5个字符和3-5个数字。
function testLink (link) {
var reg = /test.com.*-([A-Z]{4,5}[0-9]{3,5})/i;
return try { link.match(reg)[1] } catch(e) { false }
}
testLink('http://www.test.com/something-test-C34-CAA0004-CJFE348');
==> CJFE348
匹配返回带有完整测试字符串的数组,然后是我的模式。 如果失败,则try catch将被命中并返回false。 这似乎有效,但不确定是否有更好的方法? 也不确定正则表达式是否符合我的条件。 我正在建立一个需要扫描很多很多链接的功能,所以我想找到最好/最快的解决方案
您的正则表达式将匹配以test结尾的域名...
www.softwaretest.com/.....
www.valvetest.com/....
此外,你没有逃脱.
用[.]
或\\.
,所以它也会匹配
www.test1com.com/...
www.testXcom.com/....
你的正则表达式应该是
https?://(www[.])?test[.]com.*-([A-Z]{4,5}[0-9]{3,5})
功能很好,但不需要使用try-catch
:
function testLink (link) {
var your_match = link.match(/test.com.*-([A-Z]{4,5}[0-9]{3,5})/i);
// Not sure why do you want to return "false" rather than "null"
return your_match ? your_match[1] : null;
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.