JavaScript学习系列7 -- JavaScript中的运算符
今天,我们来说一说JavaScript中的运算符,首先我们来讲一讲 一元运算符
JavaScript中的一元运算符有以下几种
1. delete
delete 运算符主要用于删除对以前定义的对象属性或者方法的引用, 举个例子如下
var myObj = new Object(); // 这一句和 var myobj = new Object(); 等价
myObj.name = "Luke";
alert(myObj.name); // 输出 "Luke"
delete myObj.name;
alert(myObj.name); //输出 "undefined"
上面的例子中,通过 delete myObj.name 语句, 删除了 myObj 的name属性,这意味着强制解除对它的引用, 将其设置为 undefined (相当于 创建的未初始化的变量的值)
注意: delete 运算符不能删除开发者没有定义的属性和方法. 比如 下面的代码将引发错误
delete myObj.toString;
即使 toString是有效的方法名, 这行代码也会引发错误. 因为toString不是开发者定义的方法,而是原始的ECMAScript的方法
2. 一元加法 和 一元减法
ECMAScript 中的一元加法 和 一元减法 和我们国内数学中的用法相同
可以总结如下
一元加法 对数字没有影响,对于字符串会把字符串转化为数字
一元减法 对数字进行求负, 对于字符串会把字符串转化为数字并且求负
一元加法
一元加法 对数字完全没有任何影响, 但是在对非数值应用一元加运算符时,会调用Number()转型函数对这个值进行转换
所以,如果你对一个数字字符串(eg: "1234")应用一元加运算符,会把它转化为真正的数字 1234
var iNumber = 5;
iNumber = +iNumber;
alert(iNumber); //输出 5
var str = "5";
alert(typeof str); //输出 "string"
var iNumber = +str;
alert(typeof iNumber); //输出 "number"
var str1 = '05';
var str2 = '1.5';
var str3 = 'z';
var bValue = false;
var fValue = 1.5;
var myObj = { valueOf: function(){ return -1;
} } str1 = +str1; //输出 5
str2 = +str2; //输出 1.5
str3 = +str3; //输出 NaN
bValue = +bValue; //输出 0
fValue = +fValue; // 输出1.5
myObj = +myObj; //输出 -1
特别注意, 在new Date()前面使用一元加符号,会把日期字符串,转换为日期毫秒数
console.log(new Date()); // 输出 Wed Sep 26 2018 16:51:05 GMT+1200 (New Zealand Standard Time) console.log(+new Date()); // 输出 1537937544517
单数值数组和valueOf()返回值为数值的自定义对象会转换为数值

其他原生对象则会转换为字符串

在+运算中,和减法(-)运算中一样, undefined转换为NaN, null转换为0, false将转换为0, true将转换为1

一元减法
一元减运算符主要是用于表示负数
var num = 10;
num = -num; //输出 -10
在对非数值应用一元减运算符时,会首先调用Number()转型函数对这个值进行转换,转换为数值后,再将得到的数值转换成负数
var str1 = '05';
var str2 = '1.5';
var str3 = 'z';
var bValue = false;
var fValue = 1.5;
var myObj = { valueOf: function(){ return -1;
} } str1 = -str1; //输出 -5
str2 = -str2; //输出 -1.5
str3 = -str3; //输出 NaN
bValue = -bValue; //输出 0
fValue = -fValue; // 输出-1.5
myObj = -myObj; //输出 1

在对时间Date对象进行减法运算时,会使用Number()转换函数将时间Date对象使用ValueOf()转换为数字,再进行运算

在使用减法运算时, undefined转换为NaN, null转换为0, false将转换为0, true将转换为1

3. 递增(++) 和 递减(--)运算符
这个和C#中的用法完全相同,包括前递增(++5) 和 后递增(5++). 前递减(--5) 和 后递减 (5--)
但是有一点要注意: ++x 并不总是和 x = x+1完全一样,这是因为 ++x 会把非数字类型(比如 数字字符串)先转换为数字,再进行操作。
var x = '1';
++x; // 输出 2
但是 x+1 却会把它按照字符串连接起来, 如下
var x = '1';
x = x + 1; //输出 "11"
4. 求余(%)运算
特别注意的一点: 求余(%)运算的结果,将和第一个操作数的符号保持一致
console.log(5 % 2); //
console.log(5 % -2); // 1 注意,这里不是输出-1,和我们通常理解的不一样,求余的结果将会和第一个操作数的符号保持一致,第一个操作数5是正数,所以求余结果也是正数
console.log(-5 % 2); // -1
console.log (-5 % -2); // -1
在求余运算中,如果被除数是Infinity,或者除数是0, 则求余结果是NaN
Infinity % 0 = NaN
Infinity % Infinity =NaN
Infinity % 非0数值 = NaN
非0数值 % 0 = NaN
JavaScript学习系列7 -- JavaScript中的运算符的更多相关文章
- JavaScript学习系列5 ---ES6中的var, let 和const
我们都知道JavaScript中的var,在本系列的 JavaScript学习系列2一JavaScript中的变量作用域 中,我们详细阐述了var声明的变量的作用域 文章中提到,JavaScript中 ...
- JavaScript学习系列8 - JavaScript中的关系运算符
JavaScript中有8个关系运算符,分别是 ===, !===, ==, !=, <, <=, >, >= 1. 恒等运算符 (===) ===也叫做 严格相等运算符,它要 ...
- JavaScript学习系列4 ----- JavaScript中的扩展运算符 三个点(...)
在JavaScript中, ES6开始有rest参数 和 三个点扩展运算符 (spread运算符) 我们来看看他们各自的用处 1. rest参数 rest参数的形式为 ...变量名 ...
- JavaScript学习系列6 -- JavaScript中的垃圾回收(内存释放)
程序开发中,涉及到的内存生命周期基本是一样的,分为以下三步 1. 分配需要的内存 2. 使用分配到的内存 3. 释放其内存 ----什么时候释放内存,以及需要释放哪些变量的内存, 就是垃圾回收机 ...
- JavaScript学习系列3 -- JavaScript arguments对象学习
在实际项目开发中,目前还是很少使用到JavaScript 中的arguments对象,那么它到底是干什么用的呢 arguments是JavaScript中的一个类数组对象,它代表传给一个正在执行的函数 ...
- JavaScript学习(1)之JavaScript基础
JavaScript学习(1)之JavaScript基础 由于工作原因,开发语言逐渐以JavaScript为主,所以,抽空学习了下JavaScript语法.等现阶段的工作稳定之后,陆续会分享下自己在学 ...
- JavaScript学习系列之内存模型篇
一个热爱技术的菜鸟...用点滴的积累铸就明日的达人 正文 如果真的想学好一门语言,那么一定要了解它内存模型,本篇文章就带你走进JavaScript的内存模型,由于本人才疏学浅,若有什么表述有误的地方, ...
- JavaScript学习系列博客_1_JavaScript简介
这个系列博客主要用来记录本人学习JavaScript的笔记,从0开始,即使有些知识我也是知道的.但是会经常忘记,干脆就写成博客,没事的时候翻来看一看,留下一点学习的痕迹也好.可能写博客的水平暂时不太好 ...
- Javascript学习笔记1 javascript的特点
..对于网页而言,Javascript无处不在,对于英语不好的人它简直是噩梦般的存在,但形式所逼,今天开始着手学习!希望自己能坚持下去.从什么地方着手,我的目标是从大处着眼,从应用着眼,不抠细节,反正 ...
随机推荐
- 【转】RMQ-ST算法详解
地址:http://blog.csdn.net/z287438743z/article/details/8132806 RMQ(Range Minimum/Maximum Query)问题就是求区间最 ...
- sqoop job从创建到执行
在学习sqoop job之前,最好先学习一下sqoop命令的导入导出 sqoop 使用 import 将 mysql 中数据导入到 hive sqoop 使用 import 将 mysql 中数据导入 ...
- SESSION应用的一个场合
Session其实指的就是访问者从到达某个特定主页到离开为止的那段时间.每 一访问者都会单独获得一个Session.在Web应用程序中,当一个用户访问该应用 时,Session类型的变量可以供这个用户 ...
- java:Map借口及其子类HashMap四
java:Map借口及其子类HashMap四 使用非系统对象作为key,使用匿名对象获取数据 在Map中可以使用匿名对象找到一个key对应的value. person: public class Ha ...
- PHP限制IP访问 只允许指定IP访问 允许*号通配符过滤IP
/** * 检测访问的ip是否为规定的允许的ip * Enter description here ... */ function check_ip(){ $ALLOWED_IP=array('192 ...
- 图像处理检测方法 — ORB(Oriented FAST and Rotated BRIEF)
1.FAST FAST算子的基本原理是:若某像素点与其周围领域内足够多的连续的像素点存在某一属性差异,并且该差异大于指定阈值,则可以断定该像素点与其邻域像素有可被识别的不同之处,可以作为一个特征点( ...
- Idea_学习_06_IntelliJ IDEA 自动导入包 快捷方式 关闭重复代码提示
二.参考资料 1.IntelliJ IDEA 自动导入包 快捷方式 关闭重复代码提示
- Fiddler + 海马模拟器转包教程
Fiddler + 海马模拟器转包教程 转包用来做什么不说了, 整理一下步骤 1.安装Fiddler 下载地址 http://pan.baidu.com/s/18me0A 2.设置Fiddler: ...
- Eclipse 反编译插件安装jad【转】
原文地址:http://tangmingjie2009.iteye.com/blog/1916992 Eclipse的反编译插件一直在用jad,感觉很不错. 刚下了个新版的eclipse,配置jad的 ...
- BZOJ1217:[HNOI2003]消防局的设立
我对贪心的理解:https://www.cnblogs.com/AKMer/p/9776293.html 题目传送门:https://www.lydsy.com/JudgeOnline/problem ...