console.log()和alert()區別
之所以要對比標題中的兩個方法,是因為它們都可能會用在程式碼除錯中。
比如想要看看一段程式碼會輸出何種結果,可能會使用如下類似程式碼:
[JavaScript] 純文字檢視 複製程式碼for(var index=0;index<10;index++){ index=index+index*2; } console.log(index);
上面程式碼沒有任何其他用意,僅僅是演示console.log()的列印功能。
谷歌控制檯效果截圖如下:
紅框中的數字就是console.log方法列印結果。
如果替換成alert(),那麼就會彈出一個警告框,更加醒目。
由此看起來好像這兩個方法對於除錯各有特點,但更為有經驗的程式設計師通常使用console.log。
console.log特點:
(1).console.log方法不會中斷程式碼的執行,而alert會:
程式碼例項如下:
[JavaScript] 純文字檢視 複製程式碼for(var index=0;index<10;index++){ console.log(index); }
谷歌控制檯程式碼執行截圖如下:
console.log不會中斷程式碼的執行,這樣非常便於逐行分析程式碼的執行情況。
而alert則每執行一次就彈出一個數字,甚至感覺比較煩,也難於細緻的分析程式碼。
但也不能一概而論,可能某些時候,就是需要使用alert彈出一些東西。
二.console.log可以列印物件內部結構:
有時候需要分析一個物件的內部結構,程式碼例項如下:
[JavaScript] 純文字檢視 複製程式碼let obj={ webName:"螞蟻部落", age:5 } console.log(obj);
假設我們對obj物件內部結構毫不知情,那麼可以使用console.log列印一下:
但是alert則不會有這效果,因為它它會隱式的呼叫相應物件的toString()方法:
[JavaScript] 純文字檢視 複製程式碼let obj={ webName:"螞蟻部落", age:5 } alert(obj);
只會彈出下面這個東西:
相關文章
- 和區別
- ../和./和/的區別
- if …if 和if …else if 區別
- 和 的區別
- as 和 with的區別
- in 和 exists區別
- ||和??的區別
- /*和/**的區別
- LinkedList和ArrayList的區別、Vector和ArrayList的區別
- http和https的區別/get和post的區別HTTP
- undefined 和 null 區別?UndefinedNull
- SSL和TLS 區別TLS
- ./ 和sh 的區別
- JQuery this和$(this)的區別jQuery
- jquery $(this) 和this的區別jQuery
- ClassNotFoundException和NoClassDefFoundError區別ExceptionError
- T和?的區別
- SCSS 和 SASS 區別CSS
- innerHTML 和 innerTEXT 區別HTML
- null和undefined區別NullUndefined
- url和uri區別
- get和post區別
- ++a和a++的區別
- NoClassDefFoundError和ClassNotFoundException區別ErrorException
- $(":input")和$("input")區別
- $(document)和$(window)區別
- input和textarea區別
- localStorage和sessionStorage區別Session
- Session 和 Cookie 區別SessionCookie
- jQuery not()和filter()區別jQueryFilter
- define和defined區別
- restore和recover 區別REST
- memcache和redis區別Redis
- Antelope 和Barracuda區別
- a :hover 和a:hover 區別
- Forword和SendRedirect區別
- rbegin 和 end 區別
- setImageResource和setImageDrawable區別