javascript中2个感叹号的用法实例详解
作者:bea
在javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下: javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。 一、应用场景:判断一个对象是否存在 假设有这样一个json对象: { color: "#E3E3E3", "font-weight": "bold" } 需要判断是否存
在javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下:
javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。
一、应用场景:判断一个对象是否存在
假设有这样一个json对象:
{ color: "#E3E3E3", "font-weight": "bold" }
需要判断是否存在,用!!再好不过。
如果仅仅打印对象,无法判断是否存在:
var temp = { color: "#A60000", "font-weight": "bold" };
alert(temp);
结果:[object: Object]
如果对json对象实施!或!!,就可以判断该json对象是否存在:
var temp = { color: "#A60000", "font-weight": "bold" };
alert(!temp);
结果:false
var temp = { color: "#A60000", "font-weight": "bold" };
alert(!!temp);
结果:true
二、通过!或!!把各种类型转换成bool类型的惯例
1.对null的"非"返回true
var temp = null;
alert(temp);
结果:null
var temp = null;
alert(!temp);
结果:true
var temp = null;
alert(!!temp);
结果:false
2.对undefined的"非"返回true
var temp;
alert(temp);
结果:undefined
var temp;
alert(!temp);
结果:true
var temp;
alert(!!temp);
结果:false
3.对空字符串的"非"返回true
var temp="";
alert(temp);
结果:空
var temp="";
alert(!temp);
结果:true
var temp="";
alert(!!temp);
结果:false
4.对非零整型的"非"返回false
var temp=1;
alert(temp);
结果:1
var temp=1;
alert(!temp);
结果:false
var temp=1;
alert(!!temp);
结果:true
5.对0的"非"返回true
var temp = 0;
alert(temp);
结果:0
var temp = 0;
alert(!temp);
结果:true
var temp = 0;
alert(!!temp);
结果:false
6.对字符串的"非"返回false
var temp="ab";
alert(temp);
结果:ab
var temp="ab";
alert(!temp);
结果:false
var temp="ab";
alert(!!temp);
结果:true
7.对数组的"非"返回false
var temp=[1,2];
alert(temp);
结果:1,2
var temp=[1,2];
alert(!temp);
结果:false
var temp=[1,2];
alert(!!temp);
结果:true
相信本文所述对大家的javascript程序设计的学习有一定的借鉴价值。
猜你喜欢
您可能感兴趣的文章:
- jQuery表格插件datatables用法总结
- jQuery中index()的用法分析
- 使用jquery解析XML的方法
- JavaScript避免内存泄露及内存管理技巧
- javascript获取dom的下一个节点方法
- 原生JavaScript生成GUID的实现示例
- javascript动态控制服务器控件实例
- setTimeout()递归调用不加引号出错的解决方法
- jQuery动态创建html元素的常用方法汇总
- jquery单行文字向上滚动效果的实现代码
- Javascript保存网页为图片借助于html2canvas库实现
- JavaScript立即执行函数的三种不同写法
- JavaScript实现生成GUID(全局统一标识符)
- JavaScript判断textarea值是否为空并给出相应提示
- Firefox下无法正常显示年份的解决方法
- window.location的重写及判断location是否被重写
- js怎么覆盖原有方法实现重写
- JS的location.href跳出框架打开新页面的方法
- 手机号码,密码正则验证