我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript初学者容易犯的几个错误

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript初学者容易犯的几个错误

前言

抛开 JavaScript 语言设计层面的问题不说,毕竟它是 Brendan Eich 当年用短短十天时间设计出来的,有点缺陷也是在所难免。作为开发者,我们该怎样避免一些常见的低级错误呢?本文就列举几个常见错误,看看你有没有似曾相识。

混淆 undefined 和 null

JavaScript 中的undefined和null都可用来表示没有值,但是二者之间有所区别。undefined字面意思是“未定义”,但它的含义其实已经超出了变量未定义的范畴:尝试读取对象不存在的属性、没有return语句的函数的返回值、声明后没有赋值的变量甚至显式赋值为undefined的变量等,它们的结果都是undefined。用typeof测试它的类型,是字符串'undefined'。而null就比较纯粹了,变量只有设置为null才有这个值。另外,null是对象类型,即typeof(null)的值是字符串'object'。

需要注意的是,用if判断这两个值都是false,而且null==undefined是成立的,这一点初学者通常容易搞混。因此,尽量统一把“没有值”都设置为undefined,这样就省去了判断区分的麻烦。

返回undefined的函数:


const f = () => {}

设置变量的值为undefined:


x = undefined;

判断属性是否为undefined:


typeof obj.prop === 'undefined'
obj.prop === undefined

判断变量是否为undefined:


typeof x === 'undefined'

变量声明后没有赋值,自动就有了undefined值。

如果一定要判断null,用全等判断:


obj.prop === null
x === null

使用typeof是无法判断null的,因为它是对象类型。

混淆数字相加和字符串拼接

在 JavaScript 中,加号+操作符既可用于数字相加,也可以用于字符串拼接。由于 JavaScript 是动态语言,操作符会自动将变量转成相同数据类型再运算。比如:


let x = 1 + 1; // 2

结果是 2,是我们期望的数字相加操作,因为两个值都是数字。

但是,如果是下面这种表达式:


let x = 1 + '1'; // “11”

结果是'11',因为第一个数字会转换成字符串。这里的加号+运算符被用作字符串拼接,而不是数字相加。这里能直接看到表达式的值还算清楚,如果是由多个变量组成的表达式就很难判断类型了。

为了解决这个问题,我们可以把字符串都转成数字类型,再进行运算。例如:


let x = 1;  
let y = '2';  
let z = Number(x) + Number(y);

这样,运行结果就是3了。Number函数接收任意类型的值,如果能转成数字就返回数字,否则返回NaN。还可以用new Number(...).valueOf()函数:


let x = 1;  
let y = '2';  
let z = new Number(x).valueOf() + new Number(y).valueOf();

由于new Number(...)是实例化一个构造函数,返回的是一个对象,并不是数字类型。如果要得到原始的数字类型,需要用该对象的valueOf方法。其实还有个更简洁的方法:


let x = 1;  
let y = '2';  
let z = +x + +y;

变量前面的 + 作用是将它转换成数字,或者NaN,跟Number函数的作用相同。

return 语句换行问题

JavaScript 语法规定换行代表语句结束。例如:


const add = (a, b) => {  
  return  
  a + b;  
}
add(1,2); // undefined

本以为会返回 3,实际上是undefined。这是因为在a + b之前,函数已经执行了return。要解决这个问题,有两个做法:要么把表达式跟return放在一行,要么把表达式套一层括号。


const add = (a, b) => {  
  return a + b;  
}
// 或者
const add = (a, b) => {  
  return (  
    a + b  
  );  
}

加括号为什么可以换行呢?因为括号里的是表达式,不是语句。表达式可以拆成多行,如果很长的话。用箭头函数会更直观:


const add = (a, b) => a + b

箭头函数里的单行表达式自带return效果,当然也可以在表达式外面套一层括号:


const add = (a, b) => (a + b)

这个括号在返回对象字面量的箭头函数里有点用处,因为不加圆括号()的话,{}只是函数体的开始和结束标记,要返回对象字面量,还要显式return {...}。

如果某行代码中的语句不完整,JavaScript 解析器会将下一行的语句合并一起解析。比如:


const power = (a) => {  
  const  
    power = 10;  
  return a ** 10;  
}
// 等同于:
const power = (a) => {  
  const  power = 10;  
  return a ** 10;  
}

但是对于完整的语句,比如return,就不会合并多行。

用 return 跳出 forEach 循环

JavaScript 数组有个 forEach 方法,用于对数组元素进行循环操作。初学者很容易联想到 for循环的break或continue关键字,用来中止循环。但是对不起,forEach没有这两个关键字。那用return行不行?可以用,但它的作用就是提前返回函数,跟continue的效果类似,用于结束本次循环。要跳出整个循环,return做不到。


const nums = [1, 2, 3, 4, 5, 6];
let firstEven;
nums.forEach(n => {
  if (n % 2 ===0 ) {
    firstEven = n;
    return n;
  }
});
console.log(firstEven); // 6

代码本意是想找出第一个偶数,找到就退出循环。但实际并没有退出循环,因此最终结果是最后一个偶数。
有解决办法吗?这种情况可以用for循环,或者用数组filter、find之类的方法。

总结

虽然 JavaScript 很容易上手,但稍不注意还是比较容易犯错。本文简单介绍了几种容易犯的错,希望对你有所帮助。

以上就是JavaScript初学者容易犯的几个错误的详细内容,更多关于JS的资料请关注编程网其它相关文章!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript初学者容易犯的几个错误

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

pandas初学者容易犯的错误有哪些

这篇文章给大家分享的是有关pandas初学者容易犯的错误有哪些的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。使用pandas自带的函数读取大文件第一个错误与实际使用Pandas完成某些任务有关。具体来说我们在实际
2023-06-25

C语言中动态内存管理初学者容易犯的6个错误分享

本篇文章主要介绍了初学者使用C语言中动态内存管理的4个函数时最容易犯的6个错误,以及如何避免这些错误,文中的示例代码讲解详细,感兴趣的可以了解一下
2023-05-14

Python新手们容易犯的几个错误总结

前言 这篇文章主要给大家总结了关于学习Python的新手们容易犯的几个错误,一共四个易犯错误,下面来看看详细的介绍吧。 一、i+=1 不等于++i 初学者对Python语言不是特别了解的话,又正好有c++,java的语言背景,很容易把++i
2022-06-04

C语言中动态内存管理初学者容易犯的错误有哪些

这篇“C语言中动态内存管理初学者容易犯的错误有哪些”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言中动态内存管理初学者容
2023-07-05

Linux新手容易犯的7个错误是什么

本篇内容介绍了“Linux新手容易犯的7个错误是什么”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!7. 选择错误的 Linux 发行版Lin
2023-06-16

揭秘 JavaScript 错误对象的奥秘:初学者指南

JavaScript 错误对象提供有关错误的重要详细信息,包括类型、错误消息和错误源代码的位置。本文将详细介绍 JavaScript 错误对象,指导初学者掌握其用法。
揭秘 JavaScript 错误对象的奥秘:初学者指南
2024-03-05

初学者投放AdWords的26个错误分别是哪些

本篇文章给大家分享的是有关初学者投放AdWords的26个错误分别是哪些,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。1、在设置你的竞价广告时,选择所有的GOOLE默认设置。我
2023-06-12

JavaScript 错误对象 101:对初学者友好的完整指南

JavaScript 错误对象:初学者友好的完整指南
JavaScript 错误对象 101:对初学者友好的完整指南
2024-03-05

编程热搜

目录