首页 > web前端 > js教程 > 正文

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

php中文网
发布: 2016-05-16 16:37:09
原创
1655人浏览过

javascript代码中经常会见到!!的情况,本文即以实例形式较为深入的分析javascript中2个感叹号的用法。分享给大家供大家参考之用。具体分析如下:

javascript中的!!是逻辑"非非",即是在逻辑“非”的基础上再"非"一次。通过!或!!可以将很多类型转换成bool类型,再做其它判断。

一、应用场景:判断一个对象是否存在

假设有这样一个json对象:

{ color: "#E3E3E3", "font-weight": "bold" }
登录后复制

需要判断是否存在,用!!再好不过。

立即学习Java免费学习笔记(深入)”;

如果仅仅打印对象,无法判断是否存在:

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);
登录后复制

结果:空

西语写作助手
西语写作助手

西语助手旗下的AI智能写作平台,支持西语语法纠错润色、论文批改写作

西语写作助手 21
查看详情 西语写作助手
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程序设计的学习有一定的借鉴价值。

相关标签:
java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号