JavaScript 59 JavaScript 常见错误
JavaScript
文章目录
- JavaScript
- 59 JavaScript 常见错误
- 59.1 意外使用赋值运算符
- 59.2 期望松散的比较
- 59.3 令人困惑的加法和级联
- 59.4 令人误解的浮点
- 59.5 对 JavaScript 字符串换行
- 59.6 错位的分号
- 59.7 对 return 语句进行换行
- 59.8 解释
- 59.9 通过命名索引来访问数组
- 59.10 用逗号来结束定义
- 59.11 Undefined 不是 Null
- 59.12 期望块级范围
59 JavaScript 常见错误
一些常见的 JavaScript 错误。
59.1 意外使用赋值运算符
如果程序员在 if
语句中意外使用赋值运算符(=
)而不是比较运算符(===
),JavaScript 程序可能会产生一些无法预料的结果。
这条 if
语句返回 false
(正如预期),因为 x 不等于 10:
var x = 0;
if (x == 10)
这条 if
语句返回 true
(也许不像预期),因为 10 为 true:
var x = 0;
if (x = 10)
这条 if
语句返回 false
(也许不像预期),因为 0 为 false:
var x = 0;
if (x = 0)
赋值总是返回赋值的值。
59.2 期望松散的比较
在常规比较中,数据类型不重要。这条 if
语句返回 true
:
var x = 10;
var y = "10";
if (x == y)
在严格比较中,数据类型确实重要。这条 if
语句返回 false
:
var x = 10;
var y = "10";
if (x === y)
有一个常见的错误是忘记在 switch
语句中使用严格比较:
这条 switch
语句会显示提示框:
var x = 10;
switch(x) {case 10: alert("Hello");
}
这条 switch
语句不会显示提示框:
var x = 10;
switch(x) {case "10": alert("Hello");
}
59.3 令人困惑的加法和级联
加法用于加数值。
级联(Concatenation)用于加字符串。
在 JavaScript 中,这两种运算均使用相同的 + 运算符。
正因如此,将数字作为数值相加,与将数字作为字符串相加,将产生不同的结果:
var x = 10 + 5; // x 中的结果是 15
var x = 10 + "5"; // x 中的结果是 "105"
如果是两个变量相加,很难预测结果:
var x = 10;
var y = 5;
var z = x + y; // z 中的结果是 15var x = 10;
var y = "5";
var z = x + y; // z 中的结果是 "105"
59.4 令人误解的浮点
JavaScript 中的数字均保存为 64 位的浮点数(Floats)。
所有编程语言,包括 JavaScript,都存在处理浮点值的困难:
var x = 0.1;
var y = 0.2;
var z = x + y // z 中的结果并不是 0.3
为了解决上面的问题,请使用乘除运算:
var z = (x * 10 + y * 10) / 10; // z 中的结果将是 0.3
59.5 对 JavaScript 字符串换行
JavaScript 允许您把一条语句换行为两行:
var x =
"Hello World!";
但是,在字符串中间来换行是不对的:
var x = "Hello
World!";
如果必须在字符串中换行,则必须使用反斜杠:
var x = "Hello \
World!";
59.6 错位的分号
因为一个错误的分号,此代码块无论 x 的值如何都会执行:
if (x == 19);
{// code block
}
59.7 对 return 语句进行换行
在一行的结尾自动关闭语句是默认的 JavaScript 行为。
正因如此,下面两个例子返回相同的结果:
function myFunction(a) {var power = 10 return a * power
}
function myFunction(a) {var power = 10;return a * power;
}
JavaScript 也允许您将一条语句换行为两行。
function myFunction(a) {varpower = 10; return a * power;
}
但是,如果把 return
语句换行为两行会发生什么呢:
function myFunction(a) {varpower = 10; returna * power;
}
此函数将返回 undefined
!
因为 JavaScript 认为你的意思是:
function myFunction(a) {varpower = 10; return;a * power;
}
59.8 解释
如果某条语句是不完整的:
var
JavaScript 将通过读取下一行来完成这条语句:
power = 10;
但是由于这条语句是完整的:
return
JavaScript 会自动关闭该语句:
return;
发生这种情况是因为,在 JavaScript 中,用分号来关闭(结束)语句是可选的。
JavaScript 会在行末关闭 return
语句,因为它本身就是一条完整的语句。
所以,绝不要对 return
语句进行换行。
59.9 通过命名索引来访问数组
很多编程语言支持带有命名索引的数组。
带有命名索引的数组被称为关联数组(或散列)。
JavaScript 不支持带有命名索引的数组。
在 JavaScript 中,数组使用数字索引:
var person = [];
person[0] = "Bill";
person[1] = "Gates";
person[2] = 46;
var x = person.length; // person.length 将返回 3
var y = person[0]; // person[0] 将返回 "Bill"
在 JavaScript 中,对象使用命名索引。
如果您使用命名索引,那么在访问数组时,JavaScript 会将数组重新定义为标准对象。
在自动重定义之后,数组方法或属性将产生未定义或非正确的结果:
var person = [];
person["firstName"] = "Bill";
person["lastName"] = "Gates";
person["age"] = 46;
var x = person.length; // person.length 将返回 0
var y = person[0]; // person[0] 将返回 undefined
59.10 用逗号来结束定义
对象和数组定义中的尾随逗号在 ECMAScript 5 中是合法的。
【对象】
person = {firstName:"Bill", lastName:"Gates", age:62,}
【数组】
points = [35, 450, 2, 7, 30, 16,];
警告!!
Internet Explorer 8 会崩溃。
JSON 不允许尾随逗号。
【JSON】
person = {firstName:"Bill", lastName:"Gates", age:62}
【JSON】
points = [35, 450, 2, 7, 30, 16];
59.11 Undefined 不是 Null
JavaScript 对象、变量、属性和方法可以是未定义的。
此外,空的 JavaScript 对象的值可以为 null
。
这可能会使测试对象是否为空变得有点困难。
可以通过测试类型是否为 undefined
,来测试对象是否存在:
if (typeof myObj === "undefined")
但是无法测试对象是否为 null
,因为如果对象未定义,将抛出错误:
if (myObj === null)
要解决此问题,必须测试对象是否为 null
,而不是未定义。
但这仍然会引发错误:
if (myObj !== null && typeof myObj !== "undefined")
因此,在测试非 null 之前,必须先测试未定义:
【正确写法】
if (typeof myObj !== "undefined" && myObj !== null)
59.12 期望块级范围
JavaScript 不会为每个代码块创建新的作用域。
很多编程语言都是如此,但是 JavaScript 并非如此。
认为这段代码会返回 undefined
,是新的 JavaScript 开发者的常见错误:
for (var i = 0; i < 10; i++) {// 代码块
}
return i;
JavaScript 59 JavaScript 常见错误相关推荐
- [译] 学习 JavaScript:9 个常见错误阻碍你进步
本文讲的是[译] 学习 JavaScript:9 个常见错误阻碍你进步, 原文地址:Learning JavaScript: 9 Common Mistakes That Are Holding Yo ...
- javascript中的常见事件
javascript中的常见事件 (a) 窗口事件,只在body和frameset元素中才有效 1.onload,页面或者图片加载完成时 2.onunload,用户离开页面时候 (b) 表单元素事件, ...
- JavaScript在控制台常见的报错信息
JavaScript在控制台常见的报错信息 前言 一.JS的报错类型 二.具体的控制台报错分析 1.语法错误(SyntaxError) (1)违背命名规范 (2)括号不全 (3)关键字赋值 (4)函数 ...
- JavaScript 面试中常见算法问题详解
JavaScript 面试中常见算法问题详解,翻译自 https://github.com/kennymkchan/interview-questions-in-javascript.下文提到的很多问 ...
- Golang新开发者要注意的陷阱和常见错误
原文: 50 Shades of Go: Traps, Gotchas, and Common Mistakes for New Golang Devs 翻译: Go的50度灰:新Golang开发 ...
- SpringMVC接受JSON参数详解及常见错误总结我改
SpringMVC接受JSON参数详解及常见错误总结 最近一段时间不想使用Session了,想感受一下Token这样比较安全,稳健的方式,顺便写一个统一的接口给浏览器还有APP.所以把一个练手项目的前 ...
- java 常见错误_Java常见错误的十大列表(前100名!)
java 常见错误 前10名名单非常受欢迎,有趣且内容丰富. 但是有很多! 如何选择合适的? 这是一个元前10名列表,可帮助您找到前10名的前10名列表. 在更令人讨厌的笔记上: SELECT TOP ...
- Hibernate常见错误
Hibernate常见错误 1.错误:object references an unsaved transient instance - save the transient instance bef ...
- angularjs常见错误_AngularJS开发人员应避免的7大错误
angularjs常见错误 AngularJS is one of the powerful tools, used for managing the display of data. It is t ...
最新文章
- php 调用vs2013 dll文件,VScode能编辑DLL库文件么
- struts2 中的 addActionError 、addFieldError、addActionMessage方法的区别
- 朴素贝叶斯—疾病的预测
- linux 我的世界 跨平台联机,我的世界跨平台联机 PC、手机等平台数据互通
- python用http协议传数据_python基础 -- 简单实现HTTP协议
- php的事务没有结束,PHP PDO – 没有活动事务
- 华润燃气各大区总经理_华润燃气“十四五”战略研讨会在华润大学小径湾校区举办...
- 一个导出类的内部函数的dll
- adb命令启动某个action_Android adb shell启动应用程序的方法
- boost准模板库内存管理中pool和object_pool的使用
- Linux select 机制深入分析
- 【FreeSwitch开发实践】使用SIP客户端Yate连接FreeSwitch进行VoIP通话
- mosquitto无法连接
- Word中页眉文字下横线如何变化粗细线型,页脚文字上方如何添加横
- Pinterest模式的魅力何在?国内山寨有哪些?
- Googler在中国的“幸福”生活
- agc001E BBQ Hard
- 红石外汇|每日分享:0.667是澳元多头在FOMC会议前的最后一道防线
- ChatGPT功能介绍 ChatGPT都能做什么
- 分析|用户与我没有强关系,如何转化变现?