比如说你有这么一个东西:
var a = document.getElementById("test")
如果说你想判断a是不是空值,那就可以这样
if (!a) {
//code here
}
因为null和undefined在js里面都是可以当做FALSE来用的,所以可以直接这么用if来判断
这个是一个多行文本框还是单行文本框,如果是多行,建议用textarea。如果是单行文本框,设置type为text,并设置value="" 即为空值了。
<input name="news_abstract" id="news_abstract" style="width: 650px" type="text" value="" />
如果是多行文本框,标签内不写内容就是空值了:
<textarea name="news_abstract" id="news_abstract" style="width: 650px"></textarea>
理解与区别JavaScript中所有的"空值"和"假值",除了boolean值本身就是true和false这两种情况外,其它数据类型的"空值"主要是undefined和defined这两大类。这些空值的类型分别是:
复制代码代码示例:
typeof(undefined) == 'undefined'
typeof(null) == 'object'
typeof("") == 'string'
typeof(0) == 'number'
typeof(false) == 'boolean'
以上值的共同点:
在if语句中做判断,都会执行false分支。
从广义上来看,这些数值都是其对应数据类型上的无效值或空值。还有这五个值作!运算,结果全为:true。
不同点:
其中undefined和null比较特殊,虽然null的类型是object,但是null不具有任何对象的特性。
并不能执行null.toString()、null.constructor等对象实例的默认调用。
可以这样理解,null和undefined有最大的相似性。看看null == undefined的结果(true)也就更加能说明这点。不过相似归相似,还是有区别的,就是和数字运算时,10 + null结果为:10;10 + undefined结果为:NaN。
另外""、0和false虽然在if语句表现为"假值",可它们都是有意义数据,只是被作为了"空值"或"假值",因为:"".toString(),(0).toString()和false.toString()都是合法的可执行表达式。
注意:区分这些值,主要在于转换为String时的差异是比较大的,它们到String的转换关系是:
复制代码代码示例:
String(undefined) ->"undefined"
String(null) ->"null"
String("") ->""
String(0) ->"0"
String(false) ->"false"
这个转换关系在做字符串累加时,需要特别的注意。
否这会出些意想不到的问题,比如可能会遇到null被默认转为"null"的情况,搞的你相当的迷糊。