使用RegEx查找URL,但不查找其后的值
我看到一些关于这方面的帖子,但它们都是针对PHP的(我需要JavaScript(实际上是ActionScript(.,因为ActionScript扩展了JavaScript)),所以我的问题是如何最多捕获逗号、句号、问号或感叹号。
这就是我目前所拥有的
instructionText.replace(/(https?://w.*[w])/gi, "<a href='$1' target='_blank'>$1</a>");
但是当我使用文本"accesshttp://www.google.com.hello world"时,它捕获了hello world部分。
上面捕获组的结果是"http://google.com.Hello world"。显然,我不想要URL之后的任何内容。它们应该是简单URL。
主要是,我只想为这些".,!?"添加一张支票或空格字符并结束捕获组。它不一定要完美。
btw不确定您是否有东西要先测试RegEx,但如果没有,您可以使用RegExr。解决方案
假定URL中没有空格,后面有空格或字符串结尾:
instructionText.replace( /(https?://S+?)(?=[.,!?]?(s|$))/g, "<a href='$1' target='_blank'>$1</a>" );
它尽可能少地捕获"http[s]://"和非空格字符,直到可以选择捕获.,!?
之一,然后捕获空格或字符串结尾。
相关文章