js替换关键词为链接,只替换一次,要避开超链接或图片

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

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

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

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

上图:


 
 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>');



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值