为了账号安全,请及时绑定邮箱和手机立即绑定

replace 全局查找

replace 全局查找

潇潇雨雨 2019-02-28 14:57:25
 想做个类似于 word的查找替换功能,给查找到的词添加标签,并设置背景,加以强调,但是在使用replace时出了故障,各位能帮我解决一下bug么?-故障的地方在这里,每一次查询都会从第一次查询到的词开始,造成了重复死循环。该怎样才能把第一次的词跳过去呢?我尝试过给查询函数添加个i;function searchs(x,y){    for( var i = 0,l = str.length;i<l; i ++ ){        str = str.replace(x,y);                        //但是仍然是死循环        i = str.charCodeAt(i) + 8;                        console.log(str);        console.log(str.length)    }    oBox.innerHTML = str;}
查看完整描述

3 回答

?
慕斯王

TA贡献1864条经验 获得超2个赞

你怎么会觉得 i 能影响到 str.replace 呢,替换的字符带原有字符的情况下最好不用 replace ,楼上换正则的方式如果高亮文字里包含正则的特殊字符就不行了。


可以这么做


function searchs(x,y){

    oBox.innerHTML = str.split(x).join(y);

}


查看完整回答
反对 回复 2019-03-12
?
侃侃无极

TA贡献2051条经验 获得超10个赞

你思路可能有问题...


let i = -1;

while ((i = str.indexOf(x)) != -1) 

    str= str.replace(x, y);

console.log(str);


查看完整回答
反对 回复 2019-03-12
?
天涯尽头无女友

TA贡献1831条经验 获得超9个赞

replace第一个参数传一个全局模式的正则就可以了


function searchs(str, match, replace) {

  const reg = new RegExp(match, 'g')

  return str.replace(reg, replace)

}


const str = 'Lorem ipsum dolor sit a met a';

const result = searchs(str, 'a', '<i>a</i>')

console.log(result)


// Lorem ipsum dolor sit <i>a</i> met <i>a</i>


查看完整回答
反对 回复 2019-03-12
  • 3 回答
  • 0 关注
  • 506 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信