写点什么

巧用控制台,提升 JavaScript 调试性能

  • 2019-11-06
  • 本文字数:2204 字

    阅读完需:约 7 分钟

巧用控制台,提升JavaScript调试性能

调试 JavaScript 代码的最简单途径就是简单地通过 console.log 方法输出结果。虽然它能用,但这并不是最理想的处理方式。如果有更好的方法,何不探索一番呢?



“来自控制台的 Hello”


console 对象提供对浏览器调试控制台的访问。仅当在浏览器上运行 JavaScript 代码(即客户端代码而非服务端代码)时,才可以使用 console 对象。不同浏览器的工作方式各不相同,但是通常都会提供一组常规功能。调试语句最棒的一点是它们兼容所有库和框架,因为它们是在核心语言中编写的。


console.log 的最基本使用场景是显示代码的输出。考虑以下代码:


function sayHello(name) {  console.log(name)}
sayHello('Indrek')
复制代码


它记录传递给 sayHello 函数的名称。



“输出传递给函数的名称”


如果我们想知道必须调用 sayHello 函数多少次,该怎么办?有一个简单的方法,称为 console.count()。

console.count

count()会输出使用该标签调用它的次数。如果没有参数,则 count()的行为就像使用默认标签调用一样。


function sayHello(name) {  console.count()  console.log(name)}
sayHello("Indrek")sayHello("William")sayHello("Kelly")
复制代码


上面的代码记录以下内容:



统计我们调用 sayHello 函数的次数


这样可以统计出调用函数的次数,但如果要统计调用相同名称函数的次数怎么办?一种方法是简单地将 name 参数传递给 count 方法。


function sayHello(name) {  console.count(name)}
sayHello("Indrek")sayHello("William")sayHello("Kelly")sayHello("Indrek")
复制代码


搞定!该函数跟踪我们用每个名称调用这个函数的次数。



统计我们说每个名字的次数

console.warn

以下方法将警告消息输出到控制台,在使用开发人员工具或 API 时非常有用。console.warn 是一种理想选择,用来让用户知道某些事情不对劲,例如省略参数或让开发人员知道 API/软件包版本已过时。


function sayHello(name) {  if(!name) {    console.warn("No name given")  }}
sayHello()
复制代码


上面的代码检查 name 参数是否传递给函数。如果未输入任何名称,则会记录一条警告消息,提示其考虑某些事项。



未传递名称时,向用户显示警告消息。

console.table

如果我们要处理数组或对象,则在显示数据时 console.table 很有用。数组中的每个元素将是表中的一行。以下面的示例为例,其中有一系列水果组成的数组。如果将 fruits 数组传递给 console.table 方法,则应该看到一个打印到控制台的表。


const fruits = ["kiwi", "banana", "strawberry"]
console.table(fruits)
复制代码


而且如果我们看一眼控制台,应该看到一个描述数组的表。



以表格形式显示数组


你可以想象一下,当我们处理具有数百个(甚至数千个)值的更大数组,这种方法会非常有用。这里有一个例子来说明问题,其中数组有更多的值。


const fruits = [  "Apple",  "Watermelon",  "Orange",  "Pear",  "Cherry",  "Strawberry",  "Nectarine",  "Grape",  "Mango",  "Blueberry",  "Pomegranate",  "Carambola",  "Plum",  "Banana",  "Raspberry",  "Mandarin",  "Jackfruit",  "Papaya",  "Kiwi",  "Pineapple",  "Lime",  "Lemon",  "Apricot",  "Grapefruit",  "Melon",  "Coconut",  "Avocado",  "Peach"];
console.table(fruits);
复制代码


而且如果我们用数组调用 console.table,我们应该看到下表。



在表格中显示所有水果


使用数组很简单。如果我们要处理的是对象呢?


const pets = {  name: "Simon",  type: "cat"};
console.table(pets);
复制代码


注意,现在我们有了一个对象而不是一个数组。该对象拥有两个键:宠物的 name 和 type。



该表没有像之前那样注销值,而是显示值以及键和值。如果我们还有一个对象并尝试将其列出,该怎么办?


const pets = {  name: "Simon",  type: "cat"};
const person = { firstName: "Indrek", lastName: "Lasn"}
console.table(pets, person);
复制代码


不出所料,两个单独的对象显示在两个不同的表中。



两个对象


如果我们想将它们配对在一个表中,则将对象包装在数组中。


const pets = {  name: "Simon",  type: "cat"};
const person = { firstName: "Indrek", lastName: "Lasn"}
console.table([pets, person]);
复制代码


现在我们将对象分组到一个表中。



通过将对象包装在数组中进行分组

console.group

在使用集合或链接数据时,请使用嵌套组来直观地关联相关消息,从而让输出井井有条。要创建一个新的嵌套块,请调用 console.group()。


console.log("This is the first level");console.group();console.log("Level 2");console.group();console.log("Level 3");console.warn("More of level 3");console.groupEnd();console.log("Back to level 2");console.groupEnd();console.log("Back to the first level");
复制代码


以下代码显示嵌套的块级控制台语句——在处理基于关系的数据时很有用。



console.groupCollapsed()方法也差不多,但是新块是折叠的,需要单击显示按钮才能读取它。

概要

请使用语言自身提供的所有工具,能用就用。简单提一下:由于 debugger 本身就值得单独一篇文章来探讨,因此我们暂时跳过了它的内容。


如果你对 debugger 感到好奇,请参阅这篇文章


如果你刚入门 JavaScript,想要学习这种语言,我建议你先阅读相关书籍,同时结合实际的构建来学习。先看一下“更聪明的JavaScript学习方式”一书,这里还列出了一些用来构建的有趣应用程序


感谢阅读。


原文链接


https://medium.com/better-programming/boost-your-javascript-debugging-skills-with-these-console-tricks-ab984c70298a


2019-11-06 16:511977
用户头像
王文婧 InfoQ编辑

发布了 126 篇内容, 共 73.4 次阅读, 收获喜欢 275 次。

关注

评论

发布
暂无评论
发现更多内容

云原生中间件 -- Redis Operator 篇

Daocloud 道客

redis 云原生 中间件 云原生中间件

一种小程序弱网离线优化的思路

阿里巴巴终端技术

小程序 弱网 体验优化

Figma禁封中国企业,下一个会是Postman吗?国产软件势在必行

Liam

后端 Postman Apifox API swagger

WMS是什么?

源字节1号

开源 后端开发

做开发这么久了,还不会搭建服务器Maven私有仓库?这也太Low了吧

冰河

系统架构 程序开发 程序员进阶 编程基础 Maven仓库

iuap助力三花控股集团打造主数据管理平台

用友BIP

用友 用友iuap

基于 EventBridge 构建 SaaS 应用集成方案

阿里巴巴云原生

云原生 SaaS

3天掌握Flask开发项目系列博客之二,操作数据库

梦想橡皮擦

3月月更

java编程技术FastDFS 安装和配置

编程江湖

推荐算法!基于隐语义模型的协同过滤推荐之商品相似度矩阵

编程江湖

大数据 算法

在线JSON格式化美化

入门小站

工具

Docker Shim 被移除,K8s v1.24 升级该怎么办

Daocloud 道客

Docker Kubernetes CRI-Dockerd

技术平台&应用开发专题月 | 企业上云利器-YMS(Yon Middleware Service)

用友BIP

用友 用友iuap

技术平台&应用开发专题月 | 业务上云后的调试利器—云机一体

用友BIP

用友 用友iuap

龙蜥开发者说来了,来看看社区一周动态还有什么? | 3.07-3.11

OpenAnolis小助手

开源 开发者 龙蜥社区 一周动态

Java有了synchronized,为什么还要提供Lock

华为云开发者联盟

Java synchronized 死锁 lock 同步代码块

这是我见过最详细的Nginx 内存池分析

Linux服务器开发

nginx 线程池 Linux服务器开发 Linux后台开发 内存池

新一代对抗作战框架MITRE Engage V1版本正式发布

青藤云安全

网络安全 青藤 青藤云安全

Web安全渗透测试基本流程

学神来啦

网络安全 Web 渗透测试 WEB安全 kali

拥抱云原生 2.0 时代,Tapdata 入选阿里云首期云原生加速器!

tapdata

数据库 实时数据服务平台

译文《Java并发编程之CAS》

潘大壮

乐观锁 并发编程 CAS 并发’ Java Concurrency

阿里云移动研发平台EMAS:2月产品动态

移动研发平台EMAS

阿里云 程序员 emas 移动端 研发工具

技术平台&应用开发专题月 | 如何保证业务服务稳定运行—用友云原生技术平台高可用能力介绍

用友BIP

用友 用友iuap

阿里IM技术分享(七):闲鱼IM的在线、离线聊天数据同步机制优化实践

JackJiang

即时通讯 IM im开发

TypeScript 2.0开启空值的严格检查

华为云开发者联盟

typescript js 空指针 ts

详细解读PolarDB HTAP的功能特性和关键技术

阿里云数据库开源

数据库 阿里云 开源 postgre polarDB

墨天轮国产数据库沙龙 | 四维纵横姚延栋 :MatrixDB,All-in-One高性能时序数据库

墨天轮

数据库 时序数据库 国产数据库 MatrixDB

为什么MySQL主键查询这么快?

蝉沐风

MySQL 索引 主键查询

坐标PCB公司,想做实时数仓、推生产线看板,和Tapdata Cloud的偶遇来得就是这么凑巧

tapdata

实时数据

由Figma封停大疆,看国产IDE如何应对与突围?

Baihai IDP

人工智能 ide AI 基础软件 国产化

深入跨国互联网业务场景,看华为云数智融合元数据如何打破“数据墙”

华为云开发者联盟

大数据 数据仓库 华为云 元数据 数智融合

巧用控制台,提升JavaScript调试性能_大前端_Indrek Lasn_InfoQ精选文章