zoukankan      html  css  js  c++  java
  • 使用 js替换网页中的关键词为链接

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

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

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

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

    上图:

    [javascript] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1.    
    2.  s = "<a href='http://www.yx129.com/bingli/1_310.html'>先看一个糖尿病病历</a> <br/>" +  
    3.          "<IMG style='vertical-align:middle' width=40 src='http://yx129.com/api/minisite/images/skin/green/doctor_thumb_100.png'/>糖尿病王医生<br/>" +  
    4.          "糖尿病简介<br/>糖尿病发病率<br/><a href='baidu.com'>糖尿病症状<br/>" +  
    5.          "</a> ";  
    6.  document.write(s);  
    7.    
    8.  a_reg = /<a(.*?)</a>/i;  //a链接的正则  
    9.  img_reg = /<img(.*?)>/i; //图片链接的正则,防止图片的title,alt什么的属性包括疾病名而误替换  
    10.  var ix = 0;  
    11.    
    12.  var arr_ele = [];  
    13.  //先把<a><img>2类标签全部替换为{{index}},然后处理剩下的文字,再把<a><img>标签的内容替换回去  
    14.  while(true){  
    15.     if(-1 == s.toLowerCase().indexOf('<a ') && -1 == s.toLowerCase().indexOf('<img ')){  
    16.         break;  
    17.     }  
    18.     a_match = s.match(a_reg);  
    19.     if(a_match){  
    20.         //console.log(a_match);  
    21.         arr_ele.push(a_match[0]);  
    22.         s = s.replace(a_reg, '{{' +ix+ '}}');  
    23.         ix++;  
    24.     }  
    25.     img_match = s.match(img_reg);  
    26.     if(img_match){  
    27.         //console.log(img_match);  
    28.         arr_ele.push(img_match[0]);  
    29.         s = s.replace(img_reg, '{{' +ix+ '}}');  
    30.         ix++;  
    31.     }  
    32.     console.log(s);  
    33. }  
    34.   
    35. document.write('<br>-------------------------<br>第1步:把链接替换为{{index}}后:<br>'+s+'<br>');  
    36.   
    37. s = s.replace(/糖尿病/i, "<a target='_blank' href='http://jibing.yx129.com/tnb'>糖尿病</a>");  
    38.   
    39. document.write('<br>-------------------------<br>第2步:添加疾病库链接后:<br>'+s+'<br>');  
    40.   
    41. if(arr_ele){  
    42.     for(var i=0; i<arr_ele.length; i++){  
    43.         s = s.replace('{{' + i + '}}', arr_ele[i]);  
    44.     }  
    45. }  
    46.   
    47. document.write('<br>-------------------------<br>第3步:把链接替换回去之后:<br>'+s+'<br>'); 
  • 相关阅读:
    运用vue-awesome-swiper实现一个slide居中一个缩小显示
    IntersectionObserver
    leetcode 加一
    Cuda总结
    webrtc 视频数据 采集 发送 接收 显示
    webrtc ice代码流程走读
    webrtc sdp 组建 流程以及 sdp协议解析
    webrtc 视频参数配置
    webrtc 线程整理
    webrtc turn协议
  • 原文地址:https://www.cnblogs.com/xiaochao12345/p/4089293.html
Copyright © 2011-2022 走看看