如何为你的JavaScript代码日志着色详解


Posted in Javascript onApril 08, 2019

前言

在使用 JavaScript 开发项目,可借助 console.log 来打印日志,以便捷分析问题;但,当接触相对比较项目,纯黑色的日志输出,就会使得其作用大大削弱;虽然 info, wran、error 等方法会区别颜色输出,但各自皆有其职责,不便挪来加以滥用;此时,就需求扩展些方法,来为你的 JavaScript 代码日志着色,使得日志可以发挥更大的价值。

要实现这个功能,其实很简单;利用 console.log 字符串替代和格式设置功能即可;下面为其格式说明符的完整列表:

说明符 输出
%s 将值格式化为字符串
%i 或 %d 将值格式化为整型
%f 将值格式化为浮点值
%o 将值格式化为可扩展 DOM 元素。如同在 Elements 面板中显示的一样
%O 将值格式化为可扩展 JavaScript 对象
%c 将 CSS 样式规则应用到第二个参数指定的输出字符串

传递到任何记录方法的第一个参数可能包含一个或多个格式说明符。格式说明符由一个 % 符号与后面紧跟的一个字母组成,字母指示应用到值的格式。字符串后面的参数会按顺序应用到占位符。

关于 console 更多功能和用法,可参见 使用控制台 | Google Developers;下面是对彩色输出 log 的一个简单示例:

console.log(`%c 倾城之链: %s`, 'color: #65c294', ': 一个蛮有用的网站')
console.log(`%c 倾城之链: %c%s`, 'color: #65c294', 'color: #1a1a1a', ': 一个蛮有用的网站')

前面提及,当涉及到较大型项目,为了能从日志显现代码大致流向,最好可以封装方法,针对不同的模块日志,以不同颜色作下区分显示;这在一定程度上可以将所打出的日志利益更大化;下面是对此的一点实践方案:

const _gLogColorObj = {
 moduleA: '#009ad6', // 青色
 moduleB: '#65c294' // 若竹色
}

const _gConsole = (theme, args) => {
 const regStr = `%c@λ~${theme.toLocaleUpperCase()}: ${_gGetMatchStr(args)}`
 const color = _gLogColorObj[theme]
 console.log(regStr, `color: ${color}`, ...args)
}

const _gRegMatchObj = {
 object: '%o',
 function: '%o',
 number: '%i',
 string: '%s',
 undefined: '%s',
 boolean: '%s'
}

const _gGetMatchStr = args => {
 const cMatchArr = []
 for (let key in args) {
 cMatchArr.push(_gRegMatchObj[typeof args[key]])
 }
 return cMatchArr.join(' ')
}

const $log = {
 moduleA: (...args) => {
 _gConsole('moduleA', args)
 },
 moduleB: (...args) => {
 _gConsole('moduleB', args)
 }
 // 您可以在此定义更多方法,来区分不同模块; 
}

上面代码中,主要基于表驱动法,根据所设计的模块名(Eg: moduleA)以及既定色值,彩色化你的 JS 代码日志输出,并指明日志所在模块;这样一来,即可使得日志输出更加清晰。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,谢谢大家对三水点靠木的支持。

Javascript 相关文章推荐
setInterval()和setTimeout()的用法和区别示例介绍
Nov 17 Javascript
Javascript中匿名函数的多种调用方式总结
Dec 06 Javascript
JS获取随机数函数可自定义最小值最大值
May 08 Javascript
图片放大镜jquery.jqzoom.js使用实例附放大镜图标
Jun 19 Javascript
JS实现在页面随时自定义背景颜色的方法
Feb 27 Javascript
JS实现漂亮的淡蓝色滑动门效果代码
Sep 23 Javascript
使用bootstrap-paginator.js 分页来进行ajax 异步分页请求示例
Mar 09 Javascript
微信小程序异步处理详解
Nov 10 Javascript
详解swiper在vue中的应用(以3.0为例)
Sep 20 Javascript
Vue实现将数据库中带html标签的内容输出(原始HTML(Raw HTML))
Oct 28 Javascript
JS算法教程之字符串去重与字符串反转
Dec 15 Javascript
vue实现登录、注册、退出、跳转等功能
Dec 23 Vue.js
详解element-ui日期时间选择器的日期格式化问题
Apr 08 #Javascript
小程序获取当前位置加搜索附近热门小区及商区的方法
Apr 08 #Javascript
服务端预渲染之Nuxt(使用篇)
Apr 08 #Javascript
vue + any-touch实现一个iscroll 实现拖拽和滑动动画效果
Apr 08 #Javascript
面试题:react和vue的区别分析
Apr 08 #Javascript
vue router 组件的高级应用实例代码
Apr 08 #Javascript
JavaScript中的一些实用小技巧总结
Apr 07 #Javascript
You might like
PHP Undefined index报错的修复方法
2011/07/17 PHP
Php header()函数语法及使用代码
2013/11/04 PHP
php中操作memcached缓存进行增删改查数据的实现代码
2014/08/15 PHP
PHP5.3以上版本安装ZendOptimizer扩展
2015/03/27 PHP
php实现将任意进制数转换成10进制的方法
2015/04/17 PHP
php使用MySQL保存session会话的方法
2015/06/18 PHP
改版了网上的一个js操作userdata
2007/04/27 Javascript
Jquery下判断Id是否存在的代码
2011/01/06 Javascript
使用js操作css实现js改变背景图片示例
2014/03/10 Javascript
JavaScript通过事件代理高亮显示表格行的方法
2015/05/27 Javascript
javascript创建cookie、读取cookie
2016/03/31 Javascript
JavaScript数组的栈方法与队列方法详解
2016/05/26 Javascript
JavaScript 拖拽实例代码
2016/09/21 Javascript
vue实现添加标签demo示例代码
2017/01/21 Javascript
vuejs指令详解
2017/02/07 Javascript
react.js使用webpack搭配环境的入门教程
2017/08/14 Javascript
vue2.0 elementUI制作面包屑导航栏
2018/02/22 Javascript
JSON.stringify()方法讲解
2019/01/31 Javascript
JavaScript遍历数组的三种方法map、forEach与filter实例详解
2019/02/27 Javascript
实现一个 Vue 吸顶锚点组件方法
2019/07/10 Javascript
浅谈vue项目用到的mock数据接口的两种方式
2019/10/09 Javascript
微信小程序网络请求实现过程解析
2019/11/06 Javascript
JavaScript随机数的组合问题案例分析
2020/05/16 Javascript
[01:56]无止竞 再出发——中国军团出征2017年DOTA2国际邀请赛
2017/07/05 DOTA
python 上下文管理器使用方法小结
2017/10/10 Python
python 输入一个数n,求n个数求乘或求和的实例
2018/11/13 Python
Django继承自带user表并重写的例子
2019/11/18 Python
Python+OpenCV+图片旋转并用原底色填充新四角的例子
2019/12/12 Python
keras 如何保存最佳的训练模型
2020/05/25 Python
Python虚拟环境venv用法详解
2020/05/25 Python
安全生产检查通报
2014/01/29 职场文书
关于旷工的检讨书
2014/02/02 职场文书
生日主持词
2014/03/20 职场文书
个人工作作风整改措施思想汇报
2014/10/13 职场文书
2014年测量员工作总结
2014/12/12 职场文书
css中z-index: 0和z-index: auto的区别
2021/08/23 HTML / CSS