>웹 프론트엔드 >JS 튜토리얼 >JavaScript 필터 키워드 예에 대한 자세한 설명

JavaScript 필터 키워드 예에 대한 자세한 설명

怪我咯
怪我咯원래의
2017-07-07 10:34:042101검색

이 글에서는 주로 JavaScript 키워드 필터링 방법을 소개합니다. 매우 좋은 참조 값을 가지고 있습니다. 아래 편집기로 살펴보겠습니다

Rendering:

더 이상 고민하지 말고 코드를 살펴보세요:

<!DOCTYPE html>
<html lang="en">
<head>
 <meta charset="UTF-8">
 <title>Title</title>
 <style>
 em { font-size: 16px; color: red; }
 </style>
</head>
<body>
 <p id="cont">JavaScript过滤关键字的方法JavaScript过滤关键字的方法</p>
 <script>
 //================================= 可用状态代码 =====================================
// var arr = [&#39;Java&#39;,&#39;关键字&#39;, &#39;方法&#39;],
// arrText = arr.join(&#39;|&#39;),
// var params = document.querySelector(&#39;#cont&#39;);
//
// // 替换关键字
// params.innerHTML = params.innerHTML.replace(new RegExp(arrText, "ig"), "<em>$&</em>");
// var arr = [];
// console.log(arr);

//================================= 修改后的代码 =====================================
 /**
 * 过滤关键字
 * @param keyArr 需要过滤的关键字数组
 * @param ele 过滤的节点
 */
 function filterContent(keyArr, ele) {
 /**
 * 一个程序的标准准则
 * 1. 可用, 可以实现核心的需求
 * 2. 健壮, 兼容性处理, 边界处理, 异常处理, 用户输入校验
 * 3. 可靠, 任何时候都要有返回值
 * 4. 宽容, 对需求宽容, 对调用着宽容, 对维护者宽容
 * 5. 精益求精, 可靠的注释...
 */
 try {
 // 检测是否为 undefined 或者为一个数组,或者数组长度是否大于 1, 这里的返回 -1 只是为了有返回值, 也可以不写
 if (keyArr === &#39;undefined&#39; || !(keyArr instanceof Array) || keyArr.length < 1) return -1;
 // 将数组里面的元素以 | 进行合并方便进行正则比较, 如 张三|李四
 var arrTxt = keyArr.join(&#39;|&#39;),
  regObj = new RegExp(arrTxt, &#39;ig&#39;);
 // 替换关键字
 ele.innerHTML = ele.innerHTML.replace(regObj, "<em>$&</em>");
 } catch (e) {
 console.log(&#39;出错啦~&#39; + e);
 }

 }
 // 调用
 var arr = [&#39;Java&#39;,&#39;关键字&#39;, &#39;方法&#39;];
 var params = document.querySelector(&#39;#cont&#39;);
 filterContent(arr, params);
 </script>
</body>
</html>

위 내용은 JavaScript 필터 키워드 예에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.