vue 敏感词过滤 前端

   日期:2020-11-01     浏览:235    评论:0    
核心提示:vue 敏感词过滤 前端根据正则来进行过滤 敏感词是一个数组 词比较多 专门存放在js文件里面 vue用 export 导出 再引入到需要用的组件里judgeBadWord(obj) { let word = words.words //获取敏感词的数组 //进行遍历 for (let i=0;i<word.length;i++) { // let arr = obj.replace(/\s+/g,"")

vue 敏感词过滤 前端

根据正则来进行过滤 敏感词是一个数组 词比较多 专门存放在js文件里面 vue用 export 导出 再引入到需要用的组件里

judgeBadWord(obj) { 
      let word = words.words //获取敏感词的数组
      //进行遍历
      for (let i=0;i<word.length;i++) { 
        
        // let arr = obj.replace(/\s+/g,"")
        this.contents = obj
        //gi g全局 i不分大小写
        let reg = new RegExp(word[i],"gi")
        //用indexOf 判断是否包含
        if(this.contents.indexOf(word[i]) !== -1){ 
          let result = this.contents.replace(reg,"***")
          this.contents = result
          return true
        }
      }
    }
    //在发送消息时进行调用就行了

刚开始这样写以为没啥问题 但是当同一句话中出现多个不同敏感词时 后面的会过滤不掉 进行改进了一下

judgeBadWord(str,badWord){ 
		//trim() 方法不会改变原始字符串 去掉首尾空白符
          this.contents = str.trim()
          var re = ''
          //正则过滤 模版字符串 \b 是一个整单词
          for(var i=0;i<badWord.length;i++){ 
            if(i==forbiddenArray.length-1)
            re += `\\b${ badWord[i]}\\b`
            else
            re += `\\b${ badWord[i]}\\b`+"|"
          }
          var reg = new RegExp(re,"gi")
          this.contents=this.contents.replace(reg,"***")
          return this.contents
        }

到这了以为可以结束了 可是敏感词里有 两个英语单词组成
hellow 是敏感词 hellow word 也是敏感词 输入hellow word 的时候 helllow会变成*** word不会 不能自己去把数组里面的字符串自己调位置吧
就 把数组进行了 排序

    //这里用map可以进行链式调用 字符串的length 从高到低排序
	let word = words.words
    this.rtn = word.map(i => ({ raw: i, len: i.length}))
                .sort((p, n) => n.len - p.len)
                .map(i => i.raw)

只是记录一下 其中性能方面还可以优化一下 不足之处 还请多多关照!!!!

 
打赏
 本文转载自:网络 
所有权利归属于原作者,如文章来源标示错误或侵犯了您的权利请联系微信13520258486
更多>最近资讯中心
更多>最新资讯中心
0相关评论

推荐图文
推荐资讯中心
点击排行
最新信息
新手指南
采购商服务
供应商服务
交易安全
关注我们
手机网站:
新浪微博:
微信关注:

13520258486

周一至周五 9:00-18:00
(其他时间联系在线客服)

24小时在线客服