JS按位非(~)运算符与~~运算符的理解分析


那么,对于typeof var!==”number”的类型来说,进行运算时,会尝试转化成32位整形数据,如果无法转换成整形数据,就转换为NaN;
JS在位运算上用了更简便的一种方法来实现这中运算,那么它的实现原理大致上可以这样理解:

复制代码 代码如下:

var testData=-2.9;
var testResult=(typeof testData==="number"&&!isNaN(testData)&&testData!==Infinity)?(testData>0)?-Math.floor(testData)-1:-Math.ceil(testData)-1:-1;

首先,如果一个数据在尝试转换为32整形数据时,结果<0,那么就需要对其上舍入,比如-2.9->-2,如果>0,对其下舍入,比如:2.6->2;
一个数据如果不能转换为32位二进制表示,就转换为NaN;继而转为-1;比如~{}/~NaN ==-1;
又比如~function(){return 100;}->-1;
在Jquery里面,有用到比如if(!~this.className.indexOf(str)){ //do some thing…..};这里,对于this.className.indexOf(str)的返回值,要么大于-1,要么就是等于-1;在其等于-1的时候,~-1===0;然后,!~-1===true;那么就可以得出this不包含str这个class名…;
对于~~运算符,同理,它也可以表示为:
复制代码 代码如下:

var testData=2.1;
var testResult=(typeof testData==="number"&&!isNaN(testData)&&testData!==Infinity)?(testData>0)?Math.floor(testData):Math.ceil(testData):0;

同样采用上下舍入的方式来理解;



相关阅读:
关于PHP操作文件的一些FAQ总结
Linux下单网卡绑定多IP与多网卡共用单IP
查看源码的工具 学习jQuery源码不错的工具
mysql 优化日记
避免Linux管理常见错误保证系统的安全
FreeBSD 4.0 Kernel Hacking Guide--i386/i386/m
jquery中实现标签切换效果的代码
判断页面是关闭还是刷新的js代码
类似框架的js代码
php继承的一个应用
Div Select挡住的解决办法
CSS3设计赛:基于纯CSS3技术的前5名设计师
几款免费开源的不用数据库的php的cms
让textarea自动调整大小的js代码
快速导航

Copyright © 2016 phpStudy |