JavaScript高级程序设计之基本概念之操作符之加性操作符第3.5.5讲笔记
来源:互联网 发布:linux 切换root用户 编辑:程序博客网 时间:2024/06/13 21:22
这两个操作符却都有一系列的特殊行为。与乘性操作符类似,加性操作符也会在后台转换不同的数据类
型。然而,对于加性操作符而言,相应的转换规则还稍微有点复杂。
1. 加法
加法操作符(+)的用法如下所示:
var result = 1 + 2;
如果两个操作符都是数值,执行常规的加法计算,然后根据下列规则返回结果:
如果有一个操作数是NaN,则结果是NaN;
如果是 Infinity 加Infinity,则结果是Infinity;
如果是-Infinity 加-Infinity,则结果是-Infinity;
如果是 Infinity 加-Infinity,则结果是NaN;
如果是+0 加+0,则结果是+0;
如果是0 加0,则结果是0;
如果是+0 加0,则结果是+0。
不过,如果有一个操作数是字符串,那么就要应用如下规则:
如果两个操作数都是字符串,则将第二个操作数与第一个操作数拼接起来;
如果只有一个操作数是字符串,则将另一个操作数转换为字符串,然后再将两个字符串拼接
起来。
如果有一个操作数是对象、数值或布尔值,则调用它们的toString()方法取得相应的字符串值,
然后再应用前面关于字符串的规则。对于undefined 和null,则分别调用String()函数并取得字符
串"undefined"和"null"。
下面来举几个例子:
var result1 = 5 + 5; // 两个数值相加
alert(result1); // 10
var result2 = 5 + "5"; // 一个数值和一个字符串相加
alert(result2); // "55"
AddExample01.htm
以上代码演示了加法操作符在两种模式下的差别。第一行代码演示了正常的情况,即5+5 等于10
(数值)。但是,如果将一个操作数改为字符串"5",结果就变成了"55"(字符串值),因为第一个操作
数也被转换成了"5"。
忽视加法操作中的数据类型是ECMAScript 编程中最常见的一个错误。再来看一个例子:
var num1 = 5;
var num2 = 10;
var message = "The sum of 5 and 10 is " + num1 + num2;
alert(message); // "The sum of 5 and 10 is 510"
AddExample02.htm
在这个例子中,变量message 的值是执行两个加法操作之后的结果。有人可能以为最后得到的字
符串是"The sum of 5 and 10 is 15",但实际的结果却是"The sum of 5 and 10 is 510"。
之所以会这样,是因为每个加法操作是独立执行的。第一个加法操作将一个字符串和一个数值(5)拼
接了起来,结果是一个字符串。而第二个加法操作又用这个字符串去加另一个数值(10),当然也会得
到一个字符串。如果想先对数值执行算术计算,然后再将结果与字符串拼接起来,应该像下面这样使用
圆括号:
var num1 = 5;
var num2 = 10;
var message = "The sum of 5 and 10 is " + (num1 + num2);
alert(message); //"The sum of 5 and 10 is 15"
在这个例子中,一对圆括号把两个数值变量括在了一起,这样就会告诉解析器先计算其结果,然后
再将结果与字符串拼接起来。因此,就得到了结果"The sum of 5 and 10 is 15"。
2. 减法
减法操作符()是另一个极为常用的操作符,其用法如下所示:
var result = 2 - 1;
与加法操作符类似,ECMAScript 中的减法操作符在处理各种数据类型转换时,同样需要遵循一些
特殊规则,如下所示:
如果两个操作符都是数值,则执行常规的算术减法操作并返回结果;
如果有一个操作数是NaN,则结果是NaN;
如果是 Infinity 减Infinity,则结果是NaN;
如果是-Infinity 减-Infinity,则结果是NaN;
如果是 Infinity 减-Infinity,则结果是Infinity;
如果是-Infinity 减Infinity,则结果是-Infinity;
如果是+0 减+0,则结果是+0;
如果是+0 减0,则结果是0;
如果是0 减0,则结果是+0;
如果有一个操作数是字符串、布尔值、null 或undefined,则先在后台调用Number()函数将
其转换为数值,然后再根据前面的规则执行减法计算。如果转换的结果是NaN,则减法的结果
就是NaN;
如果有一个操作数是对象,则调用对象的valueOf()方法以取得表示该对象的数值。如果得到
的值是NaN,则减法的结果就是NaN。如果对象没有valueOf()方法,则调用其toString()
方法并将得到的字符串转换为数值。
下面几个例子展示了上面的规则:
var result1 = 5 - true; // 4,因为true 被转换成了1
var result2 = NaN - 1; // NaN
var result3 = 5 - 3; // 2
var result4 = 5 - ""; // 5,因为"" 被转换成了0
var result5 = 5 - "2"; // 3,因为"2"被转换成了2
var result6 = 5 - null; // 5,因为null 被转换成了0
- JavaScript高级程序设计之基本概念之操作符之加性操作符第3.5.5讲笔记
- JavaScript高级程序设计之基本概念之操作符之乘性操作符第3.5.4讲笔记
- JavaScript高级程序设计之基本概念之关系操作符第3.5.6讲笔记
- JavaScript高级程序设计之基本概念之相等操作符第3.5.7讲笔记
- JavaScript高级程序设计之基本概念之相等操作符第3.5.8讲笔记
- JavaScript高级程序设计之基本概念之操作符之位操作符第3.5.2讲笔记
- JavaScript高级程序设计之基本概念之操作符之布尔操作符第3.5.3讲笔记
- JavaScript高级程序设计之基本概念之操作符之一元操作符第3.5.1讲笔记
- JavaScript高级程序设计之DOM之DOM 操作技术之操作表格第10.2.3讲
- JavaScript高级程序设计之基本概念之语法 第3.1讲笔记
- JavaScript高级程序设计之基本概念之关键字和保留字 第3.2讲笔记
- JavaScript高级程序设计之基本概念之变量第3.3讲笔记
- JavaScript高级程序设计之基本概念之数据类型第3.4讲笔记
- JavaScript高级程序设计之基本概念之语句第3.6讲笔记
- JavaScript高级程序设计之基本概念之函数第3.7讲笔记
- JavaScript高级程序设计之DOM之DOM 操作技术之动态脚本第10.2.1讲
- JavaScript高级程序设计之DOM之DOM 操作技术之动态样式第10.2.2讲
- JavaScript高级程序设计之DOM之DOM 操作技术之使用NodeList第10.2.4讲
- 矩阵乘法的并行化算法讨论
- 模拟Spring的内部实现
- Understanding the digital signature
- 黑马程序员-----java基础(面向对象基础)
- android悬浮窗口的实现 Windowmanager
- JavaScript高级程序设计之基本概念之操作符之加性操作符第3.5.5讲笔记
- 201509——hulu笔试题目——rainfall
- JAVA多线程实现的三种方式
- CMS垃圾收集器介绍
- 线段树查询2
- JavaScript高级程序设计之基本概念之关系操作符第3.5.6讲笔记
- java线程池newCachedThreadPool
- QT qDebug输出QString的中文乱码,直接输出“中文”不乱码,解决方法
- HTML中的块是什么?