js的运算
1.表达式
表达式是EMCAscript中的一个“短语”,解释器会通过计算把它转换成一个值。最简单的表达式是字面量或者变量名。
2.前置递增(++box)和后置递增(box++)的区别
看下面一段代码的实现过程:
var box = 100; alert(box++); // 100 box = box+1;先执行打印box,再赋值,100 + 1 = 101 alert(++box); // 102 box = 1+box;先赋值,再打印box, 101 + 1 = 102 age = box++; height = ++box; alert(age); //102 alert(height); //104
对比一下是不是这样:
var box = 100; age = box++; alert(age); //100
var box = 100; age = ++box; alert(age); //101
3.++号的隐含的Number的转换
3.1字符串
var box = '89'; var box1 = 'lc'; alert(typeof box); //string alert(typeof box1); //string age = ++box; age1 = ++box1; alert(typeof box); //number alert(typeof box1); //number alert(typeof age); //number alert(age1); //NaN alert(typeof age1); //number
3.2 Boolean
var box1 = false; box1++; //将false转换成0,0+1=1 alert(box1); // var box2 = true; box2++; //将true转换成1, 1+1=2 alert(box2); //2
3.3对象Object
var box= {};
alert(box); //[object object]
box++;
alert(box); //NaN
box = {
toString:function(){
return '123'
}
}
alert(typeof box); //object
box++;
alert(box); //124
alert(typeof box); //number
var box1 = {
toString :function(){
return 'lc'
}
};
box1++;
alert(box1); //NaN
alert(typeof box1); //number
4+号也有这样的功能;但是注意一点
var box = '100'; +box; //这样并不能改变变量,变量也是不能改变,只能消掉重新创建变量。(这是底层原理) alert(box); //100 alert(typeof box);//stringalert(typeof +box);//number
4.1+号对string的转换
var box = false; alert(typeof box);//boolean alert(+box); //0 alert(typeof +box); //number var box1 = true; alert(+box1);//1
4.2Object
var box = {};//+box表正数,-box表示负数
alert(box);//[object object]
alert(typeof box); //object
alert(+box); //NaN
alert(typeof +box);//number
var box1 = {
toString:function(){
return '123'
}
};
alert(+box1);//123
alert(typeof +box1); //number
5运算
var box = 1 +NaN; alert(box);//NaN var box1 = 100 + '100'; alert(box1);//100100 alert(typeof box1);//string 运算规则是:number和string的运算有一个string,‘+’号就会变string的连字符
5.()括号强制优先级
var age = '年龄:'+10+20; alert(age);//年龄:1020 var age = '年龄:'+(10+20); //括号强制优先级 alert(age);//年龄:30
6.number 和object
var box = 10 + {};
alert(box); //10[object object]
alert(typeof box);//string 很奇怪
var box = 10 + {
toString:function(){
return '20';
}
};
alert(box);//1020
alert(typeof box);//string
var box = 10 = {
toString:function(){
return 20;
}
};
alert(box);//30
alert(typeof box);//number
其他的运算转换,以后补充
js的运算的更多相关文章
- js赋值运算的理解
简介 js引擎由于为了效率,很多时候的非直接量赋值都不是copy一份在赋值给新的变量,而是一个引用 ps:直接量:直接值数字字符串等 为什么使用len = doms.length; 里的len效率要比 ...
- JS浮点数运算Bug
JS浮点数运算Bug的解决办法(转) 37.5*5.5=206.08 (JS算出来是这样的一个结果,我四舍五入取两位小数) 我先怀疑是四舍五入的问题,就直接用JS算了一个结果为:206.0849999 ...
- js浮点数运算需要注意的问题
最近在js运算浮点数时发现了一个问题.问题是这样的:js函数中处理两个浮点数的相加,为了防止出现0.1+0.2=0.30000000000000004的问题,两个数都先乘以10000后再相加,得到结果 ...
- 通过一张简单的图,让你彻底地搞懂JS的==运算
大家知道,JavaScript中的==是一种比较复杂运算,它的运算规则很奇怪,很容易让人犯错,从而成为JavaScript中“最糟糕的特性”之一. 在仔细阅读ECMAScript规范的基础上,我画了一 ...
- 一道JS 连续赋值运算的问题
原文链接:https://www.cnblogs.com/joesbell/p/6229423.html <script> var a = {n:1}; var b = a; a.x = ...
- js浮点数运算封装, 起因财务部分精确计算
目录 背景 具体代码 背景 项目中用到浮点数,Int 等 js中 Number类型比较多, 加上牵涉到财务软件, 前台js运算等. 有时候会出现精确度的问题 , 公共方法中有好事者写的方法. 此处拿来 ...
- 【转】JS浮点数运算Bug的解决办法
37.5*5.5=206.08 (JS算出来是这样的一个结果,我四舍五入取两位小数) 我先怀疑是四舍五入的问题,就直接用JS算了一个结果为:206.08499999999998 怎么会这样,两个只有一 ...
- JS小数运算失精度的问题
JS因为是解释性语言,在运算中会有丢失精度的问题,这种现象多出现在浮点型运算的情况下. 例如 5.11 * 100 得到的结果是 511.00000000000006 这种情况尤其是在处理金额的时候 ...
- JS位运算和遍历
JS位运算符 整数 有符号整数:允许使用正数和负数,第32位作为符号位,前31位才是存储位 无符号整数:只允许用正数 如果用n代表位 位数 = 2^n-1 由于位数(1.2.4.8.16...)中只有 ...
- js的运算小数点的问题
问题这样的: 37.5*5.5=206.08 (JS算出来是这样的一个结果,我四舍五入取两位小数) 我先怀疑是四舍五入的问题,就直接用JS算了一个结果为:206.08499999999998 怎么会这 ...
随机推荐
- 封装同步的UIActionSheet
封装同步的UIActionSheet 发问题 做 iOS 开发的同学想必都用过 UIActionSheet.UIActionSheet 可以弹出一个选择列表,让用户选择列表中的某一项操作.使用 UIA ...
- 新机上岗 Core i7-4790 @ 3.60GHz 四核 / 16 GB ( 金士顿 DDR3 1866MHz ) / GeForce GTX 970 ( 4 GB / 七彩虹 )
新机上岗 ==============================电脑型号 华硕 All Series 台式电脑操作系统 Windows 7 旗舰版 64位 SP1 ( DirectX 11 ) ...
- hdu Robberies
这道题目应该在理解上会有一点问题.这道题的概率不是用来加的,而是用来乘的.这道题要的是在能逃跑的前提下,获得的最大money,而题目中给的概率是被抓的概率,所以要先有一个预处理,之后只要列出状态转移方 ...
- 滴答数必须介于 DateTime.MinValue.Ticks 和 DateTime.MaxValue.Ticks 之
一个莫名其妙的问题:错误 滴答数必须介于 DateTime.MinValue.Ticks 和 DateTime.MaxValue.Ticks 之间. 参数名:ticks.这 网上找了很多,都没有一个正 ...
- A trip through the Graphics Pipeline 2011_03
At this point, we’ve sent draw calls down from our app all the way through various driver layers and ...
- ThinkPHP 学习笔记 ( 二 ) 控制器 ( Controller )
/** * ThinkPHP version 3.1.3 * 部署方式:应用部署 * 文内的 http://localhost/ 由实际主机地址代替 */ 入口文件 index.php: <?p ...
- TCP移动端跟服务器数据交互
同一台笔记本下的客户端和服务端 TCPClient 客户端: // RootViewController.h#import <UIKit/UIKit.h>#import "As ...
- Ubuntu 安装字体
将字体Copy到/usr/share/fonts/windows目录下,然后执行以下几条命令更新系统字体缓存: cd /usr/share/fonts/vista/ sudo mkfontscale ...
- Magento架构分析,Magento MVC 设计分析
Magento架构分析,Magento MVC 设计分析 分类:Magento 标签:Magento MVC.Magento架构 669人浏览 Magento 采用类似 JAVA的架构,其扩展与稳定性 ...
- 详解在bash脚本中如何获取自身路径
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )" 这是stac ...