日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 >

JavaScript tips and tricks - 4

發布時間:2025/4/5 37 豆豆
生活随笔 收集整理的這篇文章主要介紹了 JavaScript tips and tricks - 4 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

JavaScript doesn’t have block scope
Block doesn’t have scope in javascript, only function has scope.

for(var i = 0; i < 2; i ++) { } i; // 2

If you want to create scope, use anonymous function:

(function (){ for(var i = 0; i < 2; i ++) { } })(); typeof(i) === 'undefined'; // true

NaN 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.

NaN === NaN; // false

Therefore, the following code may confuse somebody:

parseInt('hello', 10); // NaN parseInt('hello', 10) == NaN; // false parseInt('hello', 10) === NaN; // false

Then, how to check whether a number is NaN or not?
A?built-in function can help you, check it:

isNaN(parseInt('hello', 10)); // true

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:

if(obj === undefined || obj === null) { }

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:

function add() { arguments.push('new value'); } add(); // error - arguments.push is not a function

Of course there?would be an error, because arguments is not a real array.
Following is the solution:

function add() { Array.prototype.push.call(arguments, 'new value'); return arguments; } add()[0]; // "new value"

Boolean and new Boolean
You’d better consider Boolean as a constructor function. It can be used to produce a Boolean literal value:

Boolean(false) === false; // true Boolean('') === false; // true

Boolean(0) is equal to !!0, which was mentioned in this post.
Also, we can use new keyword to produce a boolean object:

new Boolean(false) === false; // false new Boolean(false) == false; // true typeof(new Boolean(false)); // "object" typeof(Boolean(false)); // "boolean"

This is interesting.

總結

以上是生活随笔為你收集整理的JavaScript tips and tricks - 4的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。