使用RegEx查找URL,但不查找其后的值 [英] Find a URL with RegEx without finding the value after it

查看:14
本文介绍了使用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]://"和非空格字符,直到可以选择捕获.,!?之一,然后捕获空格或字符串结尾。

这篇关于使用RegEx查找URL,但不查找其后的值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆