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);
只會彈出下面這個東西:
相關文章
- 和區別
- ../和./和/的區別
- LinkedList和ArrayList的區別、Vector和ArrayList的區別
- http和https的區別/get和post的區別HTTP
- ||和??的區別
- /*和/**的區別
- Synchronize和ReentrantLock區別ReentrantLock
- SSL和TLS 區別TLS
- jquery $(this) 和this的區別jQuery
- ClassNotFoundException和NoClassDefFoundError區別ExceptionError
- substr()和substring()區別
- JQuery this和$(this)的區別jQuery
- insert和insertSelective區別
- SCSS 和 SASS 區別CSS
- T和?的區別
- localStorage和sessionStorage區別Session
- BeanFactory和FactoryBean區別Bean
- Swift和Kotlin區別SwiftKotlin
- makefile =和:=的區別
- undefined 和 null 區別?UndefinedNull
- ibtis # 和 ¥ 區別
- Python之“==”和“is”區別Python
- null和undefined區別NullUndefined
- ++a和a++的區別
- stringbuilder和stringbuffer區別UI
- SpringCloud和Dubbo區別SpringGCCloud
- sleep()和wait()區別AI
- JoinPoint和ProceedingJoinPoint區別
- 127.0.0.0和localhost區別localhost
- ./ 和sh 的區別
- get和post區別
- url和uri區別
- innerHTML 和 innerTEXT 區別HTML
- JavaScript alert()JavaScript
- js基本型別和引用型別區別JS型別
- workman 和swoole 區別 和異同
- Cookie 和 Session 關係和區別CookieSession
- 堆和棧的概念和區別