JavaScript 过滤关键字


Posted in Javascript onMarch 20, 2017

效果图:

JavaScript 过滤关键字

话不多说,请看代码:

<!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 = ['Java','关键字', '方法'],
// arrText = arr.join('|'),
// var params = document.querySelector('#cont');
//
// // 替换关键字
// 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 === 'undefined' || !(keyArr instanceof Array) || keyArr.length < 1) return -1;
 // 将数组里面的元素以 | 进行合并方便进行正则比较, 如 张三|李四
 var arrTxt = keyArr.join('|'),
  regObj = new RegExp(arrTxt, 'ig');
 // 替换关键字
 ele.innerHTML = ele.innerHTML.replace(regObj, "<em>$&</em>");
 } catch (e) {
 console.log('出错啦~' + e);
 }

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

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,同时也希望多多支持三水点靠木!

Javascript 相关文章推荐
JS模拟自动点击的简单实例
Aug 08 Javascript
利用js正则表达式验证手机号,email地址,邮政编码
Jan 23 Javascript
利用jquery动画特效和css打造的侧边弹出垂直导航
Apr 04 Javascript
一个简单的动态加载js和css的jquery代码
Sep 01 Javascript
JS控制弹出新页面窗口位置和大小的方法
Mar 02 Javascript
js事件监听器用法实例详解
Jun 01 Javascript
详解react-native WebView 返回处理(非回调方法可解决)
Feb 27 Javascript
js+HTML5 canvas 实现简单的加载条(进度条)功能示例
Jul 16 Javascript
Vue Render函数创建DOM节点代码实例
Jul 08 Javascript
vue实现把接口单独存放在一个文件方式
Aug 13 Javascript
vue 如何从单页应用改造成多页应用
Oct 23 Javascript
JavaScript 对象创建的3种方法
Nov 17 Javascript
Extjs表单输入框异步校验的插件实现方法
Mar 20 #Javascript
js实现鼠标拖动功能
Mar 20 #Javascript
基于vue2的table分页组件实现方法
Mar 20 #Javascript
详解Weex基于Vue2.0开发模板搭建
Mar 20 #Javascript
基于vue.js实现侧边菜单栏
Mar 20 #Javascript
微信小程序 参数传递实例代码
Mar 20 #Javascript
vue.js指令v-model使用方法
Mar 20 #Javascript
You might like
php MySQL与分页效率
2008/06/04 PHP
php求正负数数组中连续元素最大值示例
2014/04/11 PHP
php删除指定目录的方法
2015/04/03 PHP
PHP实现的登录页面信息提示功能示例
2017/07/24 PHP
PHP面向对象五大原则之单一职责原则(SRP)详解
2018/04/04 PHP
PHP date()格式MySQL中插入datetime方法
2019/01/29 PHP
奉献给JavaScript初学者的编写开发的七个细节
2011/01/11 Javascript
window.open的页面如何刷新(父页面)上层页面
2012/12/28 Javascript
jQuery方法简洁实现隔行换色及toggleClass的使用
2013/03/15 Javascript
jquery validate.js表单验证入门实例(附源码)
2015/11/10 Javascript
js实现背景图自适应窗口大小
2017/01/10 Javascript
vue渲染时闪烁{{}}的问题及解决方法
2018/03/28 Javascript
详解Js里的for…in和for…of的用法
2019/03/28 Javascript
通过JS深度判断两个对象字段相同
2019/06/14 Javascript
vue导航栏部分的动态渲染实例
2019/11/01 Javascript
修改NPM全局模式的默认安装路径的方法
2020/12/15 Javascript
[01:08:43]DOTA2-DPC中国联赛定级赛 Phoenix vs DLG BO3第一场 1月9日
2021/03/11 DOTA
浅谈Python的垃圾回收机制
2016/12/17 Python
python的多重继承的理解
2017/08/06 Python
flask入门之文件上传与邮件发送示例
2018/07/18 Python
Python爬虫的两套解析方法和四种爬虫实现过程
2018/07/20 Python
在Python dataframe中出生日期转化为年龄的实现方法
2018/10/20 Python
python 定时器,实现每天凌晨3点执行的方法
2019/02/20 Python
Python matplotlib绘制饼状图功能示例
2019/09/10 Python
python matplotlib饼状图参数及用法解析
2019/11/04 Python
Python变量、数据类型、数据类型转换相关函数用法实例详解
2020/01/09 Python
利用Pytorch实现简单的线性回归算法
2020/01/15 Python
Python faker生成器生成虚拟数据代码实例
2020/07/20 Python
如何利用Python动态模拟太阳系运转
2020/09/04 Python
CSS3 实现的加载动画
2020/12/07 HTML / CSS
英国设计师泳装、沙滩装和比基尼在线精品店:Beach Cafe
2019/08/28 全球购物
财务主管自我鉴定
2014/01/17 职场文书
普通话宣传标语
2014/06/26 职场文书
运动会广播稿100字
2014/09/14 职场文书
2014年安全保卫工作总结
2014/11/13 职场文书
2014年医院党建工作总结
2014/12/20 职场文书