JavaScript中if(!XXX)的作⽤
对于很多像我这样的⼩⽩来说,js⾥⾯很多写法都没见过,不要害怕,我们慢慢积累,总会有随⼼写代码的⼀天。
我在项⽬中遇到了下⾯的写法
var projectName = $("#projectId").find("option:selected").text();
if(!projectName){
projectName = $("#projectName").val();
}
$("#projectName").val(projectName);
其中!projectName 不知道什么意思,问了⼀下⽼程序员后是这样的:第⼀⾏代码定义projectName时取值可能为null(""),如果projectName为null的话,在if判断时就会进⼊判断,当!后⾯的变量不为null时,就不进⼊判断语句。
经过测试,得出以下结论:
逻辑对象⽆初始值或者其值为 0、-0、null、""、false、undefined 或者 NaN,那么if判断 false
测试代码实例:
<html>
<head>
<script type="text/javascript" src="jquery-3.1.1.min.js"></script>
<script>
var b;
//判断jq选择器返回的对象 ---不管id存不存在都返回jq的object对象
if($("#a")){
alert("a");
}
//未初始化的变量
if(!b){
alert("b");
}
//null
if(!null){
alert("null");
}
//数字 0
if(!0){
alert("0");
}
//数字 -0
if(!-0){
alert("-0");
}
//空字符串
if(!""){
alert("空字符");
}
}
//NaN
if(!NaN){
alert("不是数字");
}
//undefined
if(!undefined ){
alert("undefined ");
}
//dalse
if(!false){
jquery是什么有什么作用
alert("false");
}
alert("end");
}
</script>
</head>
<body><body>
</html>
根据上⾯红字的结论,对 ‘判断对象’进⾏判断时,可能会出现true或者false两个可能值(这是⼀句废话,但还是要写),当判断对象为⽆初始值或者其值为 0、-0、null、""、false、undefined 或者 NaN时,if判断出来是false,加上!就是取反,即为true,那么就将执⾏{ }⾥⾯的代码。

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。