使用 js+正则表达式为关键词添加链接


Posted in Javascript onNovember 11, 2014

要求把一段html脚本中的疾病名添加到疾病库的链接,只添加一次,要避开超链接或图片链接。

最初是用的    str.replace('糖尿病', '<a href=...>糖尿病</a>');

结果找了半天,愣是没找到替换后的效果,原来是有个图片的title中包含糖尿病,被它捷足先登了。

因此要把<a>链接、<img>标签避开,但<p><div>等标签不用避开

上图:

使用 js+正则表达式为关键词添加链接

 s = "<a href='http://www.yx129.com/bingli/1_310.html'>先看一个糖尿病病历</a> <br/>" +  

         "<IMG style='vertical-align:middle' width=40 src='http://yx129.com/api/minisite/images/skin/green/doctor_thumb_100.png'/>糖尿病王医生<br/>" +  

         "糖尿病简介<br/>糖尿病发病率<br/><a href='baidu.com'>糖尿病症状<br/>" +  

         "</a> ";  

 document.write(s);  

   

 a_reg = /<a(.*?)<\/a>/i;  //a链接的正则  

 img_reg = /<img(.*?)>/i; //图片链接的正则,防止图片的title,alt什么的属性包括疾病名而误替换  

 var ix = 0;  

   

 var arr_ele = [];  

 //先把<a><img>2类标签全部替换为{{index}},然后处理剩下的文字,再把<a><img>标签的内容替换回去  

 while(true){  

    if(-1 == s.toLowerCase().indexOf('<a ') && -1 == s.toLowerCase().indexOf('<img ')){  

        break;  

    }  

    a_match = s.match(a_reg);  

    if(a_match){  

        //console.log(a_match);  

        arr_ele.push(a_match[0]);  

        s = s.replace(a_reg, '{{' +ix+ '}}');  

        ix++;  

    }  

    img_match = s.match(img_reg);  

    if(img_match){  

        //console.log(img_match);  

        arr_ele.push(img_match[0]);  

        s = s.replace(img_reg, '{{' +ix+ '}}');  

        ix++;  

    }  

    console.log(s);  

}  

  

document.write('<br>-------------------------<br>第1步:把链接替换为{{index}}后:<br>'+s+'<br>');  

  

s = s.replace(/糖尿病/i, "<a target='_blank' href='http://jibing.yx129.com/tnb'>糖尿病</a>");  

  

document.write('<br>-------------------------<br>第2步:添加疾病库链接后:<br>'+s+'<br>');  

  

if(arr_ele){  

    for(var i=0; i<arr_ele.length; i++){  

        s = s.replace('{{' + i + '}}', arr_ele[i]);  

    }  

}  

  

document.write('<br>-------------------------<br>第3步:把链接替换回去之后:<br>'+s+'<br>');

以上就是使用 js+正则表达式为关键词添加链接的全部代码了,简单吧,有需要的小伙伴可以参考下

Javascript 相关文章推荐
javascript Array数组对象的扩展函数代码
May 22 Javascript
JS中把字符转成ASCII值的函数示例代码
Nov 21 Javascript
JavaScript自定义数组排序方法
Feb 12 Javascript
jQuery实现的经典滑动门效果
Sep 22 Javascript
不得不分享的JavaScript常用方法函数集(下)
Dec 25 Javascript
利用C/C++编写node.js原生模块的方法教程
Jul 07 Javascript
vue轮播图插件vue-awesome-swiper的使用代码实例
Jul 10 Javascript
jQuery中复合选择器简单用法示例
Mar 31 jQuery
D3.js(v3)+react 实现带坐标与比例尺的散点图 (V3版本)
May 09 Javascript
原生Vue 实现右键菜单组件功能
Dec 16 Javascript
javaScript代码飘红报错看不懂?读完这篇文章再试试
Aug 19 Javascript
vue缓存之keep-alive的理解和应用详解
Nov 02 Javascript
jQuery 动态云标签插件
Nov 11 #Javascript
javascript 回调函数详解
Nov 11 #Javascript
JSON格式化输出
Nov 10 #Javascript
再谈javascript原型继承
Nov 10 #Javascript
让angularjs支持浏览器自动填表
Nov 10 #Javascript
使用cluster 将自己的Node服务器扩展为多线程服务器
Nov 10 #Javascript
前端必备神器 Snap.svg 弹动效果
Nov 10 #Javascript
You might like
php打印输出棋盘的实现方法
2014/12/23 PHP
php创建多级目录与级联删除文件的方法示例
2019/09/12 PHP
poshytip 基于jquery的 插件 主要用于显示微博人的图像和鼠标提示等
2012/10/12 Javascript
js实现禁止中文输入的方法
2015/01/14 Javascript
jquery实现红色竖向多级向右展开的导航菜单效果
2015/08/31 Javascript
js调出上下文菜单的实例
2015/12/17 Javascript
JavaScript实现图片滑动切换的代码示例分享
2016/03/06 Javascript
jQuery为动态生成的select元素添加事件的方法
2016/08/29 Javascript
Node.js下自定义错误类型详解
2016/10/17 Javascript
浅谈JS函数定义方式的区别
2016/10/30 Javascript
vue.js获取数据库数据实例代码
2017/05/26 Javascript
使用Node.js实现RESTful API的示例
2017/08/01 Javascript
原生JS实现自定义下拉单选选择框功能
2018/10/12 Javascript
详解webpack编译速度提升之DllPlugin
2019/02/05 Javascript
ionic3双击返回退出应用的方法
2019/09/17 Javascript
js HTML DOM EventListener功能与用法实例分析
2020/04/27 Javascript
uni-app从安装到卸载的入门教程
2020/05/15 Javascript
[01:07:17]EG vs Optic Supermajor 败者组 BO3 第一场 6.6
2018/06/07 DOTA
有关wxpython pyqt内存占用问题分析
2014/06/09 Python
详解Python函数可变参数定义及其参数传递方式
2017/08/02 Python
解决pip install的时候报错timed out的问题
2018/06/12 Python
Python中py文件转换成exe可执行文件的方法
2019/06/14 Python
如何通过python实现全排列
2020/02/11 Python
Django models filter筛选条件详解
2020/03/16 Python
Window10上Tensorflow的安装(CPU和GPU版本)
2020/12/15 Python
诺心蛋糕官网:LE CAKE
2018/08/25 全球购物
LORAC官网:美国彩妆品牌
2019/08/27 全球购物
英国景点门票网站:attractiontix
2019/08/27 全球购物
自我评价中英文语句
2013/11/30 职场文书
毕业生个人的求职信范文
2013/12/03 职场文书
效能监察建议书
2014/05/19 职场文书
会议邀请函
2015/01/30 职场文书
酒店工程部的岗位职责汇总大全
2019/10/23 职场文书
使用feign服务调用添加Header参数
2021/06/23 Java/Android
css中z-index: 0和z-index: auto的区别
2021/08/23 HTML / CSS
win11开机发生死循环重启怎么办?win11开机发生死循环重启解决方法
2022/08/05 数码科技