0


使用正则表达式过滤用户生成的内容

创建一个包含敏感词汇的数组sensitiveWords

_sendCommentHandle

函数中,使用

filterSensitiveWords

函数过滤

content(需要过滤的内容)

**在你的项目中,创建一个名为

filter.js

的文件,并在其中添加以下代码:**

//敏感词库:
const sensitiveWords = ['badword1', 'badword2', 'badword3'];
//创建过滤函数:
function filterSensitiveWords(text, sensitiveWords) {
  const regexStr = sensitiveWords.map(word => `\\b${word}(s|es)?`).join("|");
  const regex = new RegExp(regexStr, "gi");
  return text.replace(regex, (match, p1) => {
    return p1 ? "***" + p1 : "***";
  });
}

export default {
  sensitiveWords,
  filterSensitiveWords,
};

导入:

import filter from '@/filter';

开始过滤:

content:需要过滤的内容,

filteredContent:过滤之后的内容
const filteredContent = filter.filterSensitiveWords(content, filter.sensitiveWords);

有需求判断有没有违禁词的可以使用

includes()

函数检查

filteredContent

是否包含 "***"(表示敏感词)继续加以下代码:

const hasSensitiveWord = this.filteredContent.includes("***");

判断 hasSensitiveWord 就可以了

标签: javascript html 前端

本文转载自: https://blog.csdn.net/weixin_44523517/article/details/130026091
版权归原作者 懒员员 所有, 如有侵权,请联系我们删除。

“使用正则表达式过滤用户生成的内容”的评论:

还没有评论