调试JavaScript代码的方法千篇一律,但最优解是……

2024-01-15 19:10

本文主要是介绍调试JavaScript代码的方法千篇一律,但最优解是……,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

全文共2770字,预计学习时长5分钟

摄影师:Tracy Adams 图片来源:Unsplash

调试JavaScript代码的方法千篇一律,都是简单地通过 console.log方法输出结果。虽然有效,但不是最优方法。为什么不去探索更好的方法呢?

“Hello from the console”

console 对象提供浏览器调试控制台访问功能。只有在浏览器上运行JavaScript代码时,才可以使用console 对象,如客户端代码,而非服务器端代码。其工作原理因浏览器而异,但通常会提供一组实际特征。因为最佳的调试语句在核心语言中生成,所以可与所有库和框架一起工作。

显示输出代码是console.log的基础应用案例。代码如下:

function sayHello(name) {

console.log(name)

}

sayHello('Indrek')

该代码记录了传递给sayHello函数的name变量。

输出传递给函数的name变量

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

console.count

count()是输出调用次数的标签。如果没有参数,count()表现为默认标签。

function sayHello(name) {

console.count()

console.log(name)

}

sayHello("Indrek")

sayHello("William")

sayHello("Kelly")

上述代码记录了以下内容:

计算调用sayHello函数的次数

由此计算出调用函数的次数,但是如果想计算调用相同name变量的函数次数呢? 可以运用将name参数传递给count的方法。

function sayHello(name) {

console.count(name)

}

sayHello("Indrek")

sayHello("William")

sayHello("Kelly")

sayHello("Indrek")

就是这样!该函数可以跟踪调用每个函数的次数。

计算调用每个函数的次数

console.warn

以下为向控制台输出警告消息的方法。在使用开发工具或APIs时有效。console.warn是让用户了解错误信息的理想方法,如省略参数,或让开发者了解不宜使用API/package版本。

function

sayHello(name)

{

if(!name) {

console.warn("No name given")

}

}

sayHello()

以上代码用于检查name参数是否传递给函数。如果没有,则记录一条警告消息,提示用户注意。

无name参数传递时,向用户显示警告消息。

console.table

在显示数据时,console.table有助于处理数组或对象。数组中的每个元素显示在表中同一行。以如下水果数组为例。若使用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()方法与此类似,但是新块是折叠的,需要单击扩展按钮才能读取。

留言 点赞 关注

我们一起分享AI学习与发展的干货
欢迎关注全平台AI垂类自媒体 “读芯术”

(添加小编微信:dxsxbb,加入读者圈,一起讨论最新鲜的人工智能科技哦~)

这篇关于调试JavaScript代码的方法千篇一律,但最优解是……的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/609912

相关文章

前端bug调试的方法技巧及常见错误

《前端bug调试的方法技巧及常见错误》:本文主要介绍编程中常见的报错和Bug,以及调试的重要性,调试的基本流程是通过缩小范围来定位问题,并给出了推测法、删除代码法、console调试和debugg... 目录调试基本流程调试方法排查bug的两大技巧如何看控制台报错前端常见错误取值调用报错资源引入错误解析错误

SpringBoot集成图片验证码框架easy-captcha的详细过程

《SpringBoot集成图片验证码框架easy-captcha的详细过程》本文介绍了如何将Easy-Captcha框架集成到SpringBoot项目中,实现图片验证码功能,Easy-Captcha是... 目录SpringBoot集成图片验证码框架easy-captcha一、引言二、依赖三、代码1. Ea

Springboot控制反转与Bean对象的方法

《Springboot控制反转与Bean对象的方法》文章介绍了SpringBoot中的控制反转(IoC)概念,描述了IoC容器如何管理Bean的生命周期和依赖关系,它详细讲解了Bean的注册过程,包括... 目录1 控制反转1.1 什么是控制反转1.2 SpringBoot中的控制反转2 Ioc容器对Bea

Spring Cloud Hystrix原理与注意事项小结

《SpringCloudHystrix原理与注意事项小结》本文介绍了Hystrix的基本概念、工作原理以及其在实际开发中的应用方式,通过对Hystrix的深入学习,开发者可以在分布式系统中实现精细... 目录一、Spring Cloud Hystrix概述和设计目标(一)Spring Cloud Hystr

C++实现回文串判断的两种高效方法

《C++实现回文串判断的两种高效方法》文章介绍了两种判断回文串的方法:解法一通过创建新字符串来处理,解法二在原字符串上直接筛选判断,两种方法都使用了双指针法,文中通过代码示例讲解的非常详细,需要的朋友... 目录一、问题描述示例二、解法一:将字母数字连接到新的 string思路代码实现代码解释复杂度分析三、

Spring Boot整合消息队列RabbitMQ的实现示例

《SpringBoot整合消息队列RabbitMQ的实现示例》本文主要介绍了SpringBoot整合消息队列RabbitMQ的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的... 目录RabbitMQ 简介与安装1. RabbitMQ 简介2. RabbitMQ 安装Spring

mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespace id不一致处理

《mysql8.0无备份通过idb文件恢复数据的方法、idb文件修复和tablespaceid不一致处理》文章描述了公司服务器断电后数据库故障的过程,作者通过查看错误日志、重新初始化数据目录、恢复备... 周末突然接到一位一年多没联系的妹妹打来电话,“刘哥,快来救救我”,我脑海瞬间冒出妙瓦底,电信火苲马扁.

springMVC返回Http响应的实现

《springMVC返回Http响应的实现》本文主要介绍了在SpringBoot中使用@Controller、@ResponseBody和@RestController注解进行HTTP响应返回的方法,... 目录一、返回页面二、@Controller和@ResponseBody与RestController

JAVA集成本地部署的DeepSeek的图文教程

《JAVA集成本地部署的DeepSeek的图文教程》本文主要介绍了JAVA集成本地部署的DeepSeek的图文教程,包含配置环境变量及下载DeepSeek-R1模型并启动,具有一定的参考价值,感兴趣的... 目录一、下载部署DeepSeek1.下载ollama2.下载DeepSeek-R1模型并启动 二、J

springboot rocketmq配置生产者和消息者的步骤

《springbootrocketmq配置生产者和消息者的步骤》本文介绍了如何在SpringBoot中集成RocketMQ,包括添加依赖、配置application.yml、创建生产者和消费者,并展... 目录1. 添加依赖2. 配置application.yml3. 创建生产者4. 创建消费者5. 使用在