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 常见错误相关推荐

  1. [译] 学习 JavaScript:9 个常见错误阻碍你进步

    本文讲的是[译] 学习 JavaScript:9 个常见错误阻碍你进步, 原文地址:Learning JavaScript: 9 Common Mistakes That Are Holding Yo ...

  2. javascript中的常见事件

    javascript中的常见事件 (a) 窗口事件,只在body和frameset元素中才有效 1.onload,页面或者图片加载完成时 2.onunload,用户离开页面时候 (b) 表单元素事件, ...

  3. JavaScript在控制台常见的报错信息

    JavaScript在控制台常见的报错信息 前言 一.JS的报错类型 二.具体的控制台报错分析 1.语法错误(SyntaxError) (1)违背命名规范 (2)括号不全 (3)关键字赋值 (4)函数 ...

  4. JavaScript 面试中常见算法问题详解

    JavaScript 面试中常见算法问题详解,翻译自 https://github.com/kennymkchan/interview-questions-in-javascript.下文提到的很多问 ...

  5. Golang新开发者要注意的陷阱和常见错误

    原文: 50 Shades of Go: Traps, Gotchas, and Common Mistakes for New Golang Devs   翻译: Go的50度灰:新Golang开发 ...

  6. SpringMVC接受JSON参数详解及常见错误总结我改

    SpringMVC接受JSON参数详解及常见错误总结 最近一段时间不想使用Session了,想感受一下Token这样比较安全,稳健的方式,顺便写一个统一的接口给浏览器还有APP.所以把一个练手项目的前 ...

  7. java 常见错误_Java常见错误的十大列表(前100名!)

    java 常见错误 前10名名单非常受欢迎,有趣且内容丰富. 但是有很多! 如何选择合适的? 这是一个元前10名列表,可帮助您找到前10名的前10名列表. 在更令人讨厌的笔记上: SELECT TOP ...

  8. Hibernate常见错误

    Hibernate常见错误 1.错误:object references an unsaved transient instance - save the transient instance bef ...

  9. angularjs常见错误_AngularJS开发人员应避免的7大错误

    angularjs常见错误 AngularJS is one of the powerful tools, used for managing the display of data. It is t ...

最新文章

  1. php 调用vs2013 dll文件,VScode能编辑DLL库文件么
  2. struts2 中的 addActionError 、addFieldError、addActionMessage方法的区别
  3. 朴素贝叶斯—疾病的预测
  4. linux 我的世界 跨平台联机,我的世界跨平台联机 PC、手机等平台数据互通
  5. python用http协议传数据_python基础 -- 简单实现HTTP协议
  6. php的事务没有结束,PHP PDO – 没有活动事务
  7. 华润燃气各大区总经理_华润燃气“十四五”战略研讨会在华润大学小径湾校区举办...
  8. 一个导出类的内部函数的dll
  9. adb命令启动某个action_Android adb shell启动应用程序的方法
  10. boost准模板库内存管理中pool和object_pool的使用
  11. Linux select 机制深入分析
  12. 【FreeSwitch开发实践】使用SIP客户端Yate连接FreeSwitch进行VoIP通话
  13. mosquitto无法连接
  14. Word中页眉文字下横线如何变化粗细线型,页脚文字上方如何添加横
  15. Pinterest模式的魅力何在?国内山寨有哪些?
  16. Googler在中国的“幸福”生活
  17. agc001E BBQ Hard
  18. 红石外汇|每日分享:0.667是澳元多头在FOMC会议前的最后一道防线
  19. ChatGPT功能介绍 ChatGPT都能做什么
  20. 分析|用户与我没有强关系,如何转化变现?

热门文章

  1. 开发 Spring 自定义视图和视图解析器
  2. 【工具】一款在线字数统计工具,统计单个字词组出现的频率
  3. esp32 cam 从安装、烧录到成为webcam详细教程
  4. 强力卸载XCode方法
  5. 【Golang】Golang语言编程规范
  6. [ 数据结构-C语言 ] 二叉树--初阶 大总结~~
  7. 设备巡检小程序开发制作功能介绍
  8. 开源即巅峰,《Java程序性能优化实战》GitHub三小时标星已超34k
  9. 主键约束和唯一性约束的区别
  10. python识别火车票二维码_Python实现查询12306火车票信息