javascript中2个感叹号的用法实例详解


Posted in Javascript onSeptember 04, 2014

在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程序设计的学习有一定的借鉴价值。

Javascript 相关文章推荐
只需一行代码,轻松实现一个在线编辑器
Nov 12 Javascript
jQuery实现动态表单验证时文本框抖动效果完整实例
Aug 21 Javascript
js如何判断输入字符串长度
Dec 16 Javascript
jQuery Validation PlugIn的使用方法详解
Dec 18 Javascript
搞定immutable.js详细说明
May 02 Javascript
Windows环境下npm install 报错: operation not permitted, rename的解决方法
Sep 26 Javascript
Vue.js双向绑定实现原理详解
Dec 22 Javascript
jQuery UI Grid 模态框中的表格实例代码
Apr 01 jQuery
详解微信小程序缓存--缓存时效性
May 02 Javascript
vue ssr服务端渲染(小白解惑)
Nov 10 Javascript
javascript利用键盘控制小方块的移动
Apr 20 Javascript
vue实现桌面向网页拖动文件的示例代码(可显示图片/音频/视频)
Mar 01 Vue.js
IE下通过a实现location.href 获取referer的值
Sep 04 #Javascript
通过location.replace禁止浏览器后退防止重复提交
Sep 04 #Javascript
下拉框select的绑定示例
Sep 04 #Javascript
javascript使用正则获取url上的某个参数
Sep 04 #Javascript
JavaScript中匿名、命名函数的性能测试
Sep 04 #Javascript
容易造成JavaScript内存泄露几个方面
Sep 04 #Javascript
require.js深入了解 require.js特性介绍
Sep 04 #Javascript
You might like
php保存二进制原始数据为图片的程序代码
2014/10/14 PHP
php集成环境xampp中apache无法启动问题解决方案
2014/11/18 PHP
Yii配置文件用法详解
2014/12/04 PHP
php 在线导入mysql大数据程序
2015/06/11 PHP
php array_map使用自定义的函数处理数组中的每个值
2016/10/26 PHP
教你如何解密js/vbs/vbscript加密的编码异处理小结
2008/06/25 Javascript
Javascript 陷阱 window全局对象
2008/11/26 Javascript
网页下载文件期间如何防止用户对网页进行其他操作
2014/06/27 Javascript
jQuery调取jSon数据并展示的方法
2015/01/29 Javascript
JS继承用法实例分析
2015/02/05 Javascript
跟我学习javascript的隐式强制转换
2015/11/16 Javascript
简述JavaScript提交表单的方式 (Using JavaScript Submit Form)
2016/03/18 Javascript
mvc 、bootstrap 结合分布式图简单实现分页
2016/10/10 Javascript
浅谈Javascript中的Label语句
2016/12/14 Javascript
JavaScript无缝滚动效果的实例代码
2017/03/27 Javascript
vue-cli+webpack记事本项目创建
2017/04/01 Javascript
javascript闭包功能与用法实例分析
2017/04/06 Javascript
jQuery实现的文字逐行向上间歇滚动效果示例
2017/09/06 jQuery
js中DOM事件绑定分析
2018/03/18 Javascript
react 组件传值的三种方法
2019/06/03 Javascript
微信小程序跨页面数据传递事件响应实现过程解析
2019/12/19 Javascript
详解微信小程序轨迹回放实现及遇到的坑
2021/02/02 Javascript
[47:02]2018DOTA2亚洲邀请赛3月29日 小组赛B组 VP VS paiN
2018/03/30 DOTA
使用paramiko远程执行命令、下发文件的实例
2017/10/01 Python
深入分析python数据挖掘 Json结构分析
2018/04/21 Python
python模块smtplib学习
2018/05/22 Python
python实现图片筛选程序
2018/10/24 Python
pandas的连接函数concat()函数的具体使用方法
2019/07/09 Python
python下PyGame的下载与安装过程及遇到问题
2019/08/04 Python
海滩咖啡馆:Beach Cafe
2018/02/02 全球购物
以太网Ethernet IEEE802.3
2013/08/05 面试题
什么是用户模式(User Mode)与内核模式(Kernel Mode) ?
2014/07/21 面试题
论文评审意见
2015/06/05 职场文书
校园安全学习心得体会
2016/01/18 职场文书
2016开学第一课心得体会
2016/01/23 职场文书
Java新手教程之ArrayList的基本使用
2021/06/20 Java/Android