文本中的url替换成可以点击的link地址

$(function(){
  content="<br>将一个用户输入的一段文本中的url替换成可以点击的link地址。<br>"
    +"<br>测试一下:(lp-p.rrrr.com紧接着还有me.ttt-tt.com)"
    +"<br>测试一下:http://www.ablanxue.com紧接着还有http://www.baidu.com"
    +"<br>测试一下复杂网址:https://zhidao.baidu.com/question/263160181132274005.html"
    +"<br>测试一下复杂网址:http://blog.csdn.net/zcjlike/article/details/71169803"
    +"<br><br>测试一下复杂网址:https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&tn=baidu&wd=%E4%B8%80%E6%AE%B5%E7%AE%80%E5%8D%95%E7%9A%84JS%E5%8F%AF%E4%BB%A5%E5%B0%86%E6%99%AE%E9%80%9A%E7%9A%84%E6%96%87%E6%9C%AC%E9%93%BE%E6%8E%A5URL%E8%BD%AC%E6%8D%A2%E6%88%90%E5%8F%AF%E7%82%B9%E5%87%BB%E7%9A%84%E8%B6%85%E9%93%BE%E6%8E%A5&oq=js%25E8%258E%25B7%25E5%258F%2596%25E6%2596%2587%25E6%259C%25AC%25E4%25B8%25AD%25E7%259A%2584url%25E9%2593%25BE%25E6%258E%25A5%252C%25E5%25B9%25B6%25E6%259B%25BF%25E6%258D%25A2a%25E6%25A0%2587%25E7%25AD%25BE&rsv_pq=a02d33130004abcc&rsv_t=4f4evz2vRTr3VcQfoLBEDiKs%2B8k334%2Fh8Ir5bG2ZDcpkmdabKM8mMEuz5qc&rqlang=cn&rsv_enter=0&inputT=1008&rsv_sug3=142&rsv_sug1=47&rsv_sug7=000&rsv_n=2&bs=js%E8%8E%B7%E5%8F%96%E6%96%87%E6%9C%AC%E4%B8%AD%E7%9A%84url%E9%93%BE%E6%8E%A5%2C%E5%B9%B6%E6%9B%BF%E6%8D%A2a%E6%A0%87%E7%AD%BE"
    +"<br><br>测试一下复杂网址:https://c.runoob.com/front-end/854"
    +"<br>测试一下:[RR^R](lp-p.rrrr.com)紧接着还有[TTTTT](me.ttt-tt.com)"
    +"<br>测试一下:[X&UE](http://www.ablanxue.com)紧接着还有[百度](http://www.baidu.com)"
    +"<br>测试一下复杂网址:[复杂'网址1](https://zhidao.baidu.com/question/263160181132274005.html)"
    +"<br>测试一下复杂网址:[复杂;网址2](http://blog.csdn.net/zcjlike/article/details/71169803)"
    +"<br><br>测试一下复杂网址:[复杂网?址3](https://www.baidu.com/s?ie=utf-8&f=8&rsv_bp=1&tn=baidu&wd=%E4%B8%80%E6%AE%B5%E7%AE%80%E5%8D%95%E7%9A%84JS%E5%8F%AF%E4%BB%A5%E5%B0%86%E6%99%AE%E9%80%9A%E7%9A%84%E6%96%87%E6%9C%AC%E9%93%BE%E6%8E%A5URL%E8%BD%AC%E6%8D%A2%E6%88%90%E5%8F%AF%E7%82%B9%E5%87%BB%E7%9A%84%E8%B6%85%E9%93%BE%E6%8E%A5&oq=js%25E8%258E%25B7%25E5%258F%2596%25E6%2596%2587%25E6%259C%25AC%25E4%25B8%25AD%25E7%259A%2584url%25E9%2593%25BE%25E6%258E%25A5%252C%25E5%25B9%25B6%25E6%259B%25BF%25E6%258D%25A2a%25E6%25A0%2587%25E7%25AD%25BE&rsv_pq=a02d33130004abcc&rsv_t=4f4evz2vRTr3VcQfoLBEDiKs%2B8k334%2Fh8Ir5bG2ZDcpkmdabKM8mMEuz5qc&rqlang=cn&rsv_enter=0&inputT=1008&rsv_sug3=142&rsv_sug1=47&rsv_sug7=000&rsv_n=2&bs=js%E8%8E%B7%E5%8F%96%E6%96%87%E6%9C%AC%E4%B8%AD%E7%9A%84url%E9%93%BE%E6%8E%A5%2C%E5%B9%B6%E6%9B%BF%E6%8D%A2a%E6%A0%87%E7%AD%BE)"
    +"<br><br>测试一下复杂网址:[复杂网$址4](https://c.runoob.com/front-end/854)";

  var regExp1 = /((http|https|ftp|mms|rtsp):\/\/)?((([\w-]+\.)+[\w-]+)(\/[\w-./?%&=]*)?)/g;//仅匹配网址url
  var regExp2 = /\[([\u4E00-\u9FA5A-Za-z0-9_^%&',;=?$]+)\]\((((http|https|ftp|mms|rtsp):\/\/)?((([\w-]+\.)+[\w-]+)(\/[\w-./?%&=]*)?))\)/g;//匹配[name](url)格式的网址,name可以是中英文及多种字符
  var regExp3 = /(\[([\u4E00-\u9FA5A-Za-z0-9_^%&',;=?$]+)\]\()?(((http|https|ftp|mms|rtsp):\/\/)?((([\w-]+\.)+[\w-]+)(\/[\w-./?%&=]*)?))(\))?/g;//匹配单独网址url和[name](url)格式的网址
  
  content1 = content.replace(regExp1, function($1,$2,$3,$4,$5,$6,$7){//缺点:当为url)格式时也会被匹配,并输出url
    //$1是url的完整匹配结果(可以含有https://等网络协议名)
    //$2是https://等网络协议名的匹配结果
    //$3是https等网络协议名的匹配结果
    //$4是url的完整匹配结果
    //$5是url的域名的匹配结果
    //$6是url的域名的第一个.号(含)前的域名匹配结果
    //$7是url的域名右侧部分的匹配结果
    return "<a href='" + $1 + "' target='_blank'>" + $4 + "</a>";
  });
  content2 = content.replace(regExp2, function($1,$2,$3,$4,$5,$6,$7,$8,$9){//缺点:当为url)格式时也会被匹配,并输出url
    //$1是完整匹配结果
    //$2是name的匹配结果
    //$3是url的匹配结果(可以含有https://等网络协议名)
    //$4是https://等网络协议名的匹配结果
    //$5是https等网络协议名的匹配结果
    //$6是url的匹配结果
    //$7是url的域名的匹配结果
    //$8是url的域名的第一个.号(含)前的域名匹配结果
    //$9是url的域名右侧部分的匹配结果
    if(typeof $2=='undefined')
      return "<a href='" + $3 + "' target='_blank'>" + $4 + "</a>";
    return "<a href='" + $3 + "' target='_blank'>" + $2 + "</a>";
  });
  content3 = content.replace(regExp3, function($1,$2,$3,$4,$5,$6,$7,$8,$9,$10){//缺点:当为url)格式时也会被匹配,并输出url
    //$1是完整匹配结果
    //$2是[name](的匹配结果
    //$3是name的匹配结果
    //$4是url的匹配结果(可以含有https://等网络协议名)
    //$5是https://等网络协议名的匹配结果
    //$6是https等网络协议名的匹配结果
    //$7是url的匹配结果
    //$8是url的域名的匹配结果
    //$9是url的域名的第一个.号(含)前的域名匹配结果
    //$10是url的域名右侧部分的匹配结果
    if(typeof $3=='undefined')
      return "<a href='" + $4 + "' target='_blank'>" + $4 + "</a>";
    return "<a href='" + $4 + "' target='_blank'>" + $3 + "</a>";
  });
  
  $("body").html(content1);
})

 

转载于:https://my.oschina.net/u/3552749/blog/1517371

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值