js中的字符串替换replace操作

replace('这里写要替换的/g/i','这里写替换后的');

i 表示忽略大小写

gi 表示全局匹配+忽略大小写

案例:在留言板里输入留言 点提交按钮之后 有'激情'就会替换成**号

<body>
    <textarea name="" id="text" cols="30" rows="10"></textarea>
    <button>提交</button>
    <div></div>
</body>
<script>
    var text = document.querySelector('#text');
    var btn = document.querySelector('button');
    var div = document.querySelector('div');
    btn.onclick = function() {
        div.innerHTML = text.value.replace(/激情/g, '**');
      //方法2 ''是字符型 但是字符型后面加g会报错
        div.innerHTML = text.value.replace('激情', '**'); 
    }
</script>

g 代表全局匹配 如果不写g 则只会把第一个‘激情’替换成星号 后面出现则不再替换

​​​​​​​

 如果有多个需要屏蔽替换的词汇 可以使用 正则表达式里的  | (或or)

这样输入激情或者其他脏词汇 都会被输出星号

如果直接想把敏感词过滤掉不显示  直接把后面的** 改为空即可 ' '

    btn.onclick = function() {
        div.innerHTML = text.value.replace(/激情|cao|骂/g, '**');
    }

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当js字符串替换replace无效的时候,我们需要检查以下几个可能出现的原因: 1. 参数传递错误:在使用replace方法时,必须传入两个参数:要被替换的字符串和替换成的新字符串。如果参数传递错误,比如顺序颠倒或者只传入了一个参数等等,都会导致替换无效。因此,我们需要检查一下参数的传递是否正确。 2. 对象不是字符串类型:replace方法只能用于字符串类型的对象。如果我们尝试使用非字符串类型的对象调用replace方法,那么替换也会无效。因此,我们需要检查一下替换的对象类型是否为字符串类型。 3. 使用正则表达式时出现问题:当我们在replace方法使用正则表达式进行替换时,如果出现问题也会导致替换无效。比如,我们可能没有正确地书写正则表达式,或者在替换时没有使用正确的标识符等等。因此,我们需要检查一下正则表达式是否正确。 4. 没有使用全局替换replace方法默认只会替换第一个匹配到的字符串。如果我们需要替换所有匹配到的字符串,就需要在正则表达式的末尾添加"g"标识符,表示进行全局替换。如果我们没有使用全局替换,那么替换也会无效。 5. 字符串不可变性:在Javascript,字符串是不可变的。也就是说,一旦字符串被创建后,就无法再进行修改。因此,我们需要将替换后的新字符串赋值给一个新的变量或者重新赋值给原变量才能让替换生效。 总之,当我们遇到js字符串替换replace无效的情况时,需要逐一排查以上几个可能出现的原因,找出问题的所在,才能解决替换无效的问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值