javascript
JavaScript tips and tricks - 4
JavaScript doesn’t have block scope
Block doesn’t have scope in javascript, only function has scope.
If you want to create scope, use anonymous function:
(function (){ for(var i = 0; i < 2; i ++) { } })(); typeof(i) === 'undefined'; // trueNaN is weird
NaN indentifies a value which is not a number.
It’s weird because comparing NaN with anything (even NaN itself) is always false.
Therefore, the following code may confuse somebody:
parseInt('hello', 10); // NaN parseInt('hello', 10) == NaN; // false parseInt('hello', 10) === NaN; // falseThen, how to check whether a number is NaN or not?
A?built-in function can help you, check it:
Truthy and falsy values
All values in javascript can be converted into boolean implied.
Note that?the following values can be converted into false ones automatically, which called falsy values:
null, undefined, NaN, 0, ‘’, false
Therefore you don’t need to do like this:
Simply do as follows:
if(!obj) { }How to modify arguments
In this post , I give a method to convert arguments into a real array.
Then, how to modify arguments?
For example, add a new value to the end of the arguments:
Of course there?would be an error, because arguments is not a real array.
Following is the solution:
Boolean and new Boolean
You’d better consider Boolean as a constructor function. It can be used to produce a Boolean literal value:
Boolean(0) is equal to !!0, which was mentioned in this post.
Also, we can use new keyword to produce a boolean object:
This is interesting.
總結
以上是生活随笔為你收集整理的JavaScript tips and tricks - 4的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 电话无人应答转总机的配置方法
- 下一篇: http://snmp.adventne