复制代码 代码如下:
result = ~ 【数字】
所有一元运算符(如 ~ 运算符)都按照下面的规则来计算表达式的值:
复制代码 代码如下:
1、 如果应用于未定义的表达式或 null 表达式,则会引发一个运行时错误。
2、 将对象转换为字符串。
3、 如果可能,将字符串转换为数字。 否则,将引发运行时错误。
4、 布尔值被视为数字(如果为 false,则为 0;如果为 true,则为 1)。
运算符将应用于结果数字。
~ 运算符查看表达式的二进制表示形式的值,并执行位非运算。
表达式中的任何一位为 1,则结果中的该位变为 0。 表达式中的任何一位为 0,则结果中的该位变为 1。
下面的示例阐释了位非 (~) 运算符的用法,其中包含二进制表示十进制负数的,如果不熟悉这个请先看懂《十进制负数转换为二进制、八进制、十六进制》。
复制代码 代码如下:
var temp = ~5;
/*
5 二进制 101,补满 32位
00000000000000000000000000000101
按位取反
11111111111111111111111111111010
由于32位开头第一个是1,所以这是一个负数,将二进制转换成负数,需要先反码
00000000000000000000000000000101
之后,再+1
00000000000000000000000000000110
转换成十进制为6,加上符号变成负数 -6
*/
alert(temp);
// 弹出【-6】
您可能感兴趣的文章:
- javascript相等运算符与等同运算符详细介绍
- js 与或运算符 || && 妙用
- javascript三元运算符用法实例
- javascript typeof的用法与typeof运算符介绍[详细]
- js中的 || 与 && 运算符详解
- JS按位非(~)运算符与~~运算符的理解分析
- JS中三目运算符和if else的区别分析与示例
- Javascript 按位左移运算符使用介绍(<<)
- JavaScript中的6种运算符总结
- JavaScript相等运算符的九条规则示例详解