JavaScript中的alert()函數(shù)使用技巧詳解
在JavaScript代碼中,可以使用window對象的alert()函數(shù)來顯示一段文本,從而進行程序的調(diào)試,或者向用戶警示相關(guān)信息:
//Use window object's alert() function
window.alert("sample text");
這一寫法可以簡化為直接使用alert()函數(shù):
//Simplified alert() usage
alert("sample text");
如果需要顯示帶換行的文本,可以使用\n:
//Use \n in alert()
alert("The first line\nThe second line");
如果需要使用制表符,可以用\t:
//Use \t in alert()
alert("Alex\t50\t34\nBob\t59\t38");
變量的使用
除了顯示靜態(tài)字符串外,alert()函數(shù)也可以接受變量,并將變量值與其它字符串進行拼接:
//Use variable in alert()
var word = "life";
alert("The magic word is: " + word + ". Don't panic.");
遺憾的是,盡管alert()函數(shù)可以接受變量,但能做的也僅止于這種字符串拼接操作;與另一種調(diào)試方法console.log()相反,alert()函數(shù)并不接受向字符串傳參數(shù)的做法。以下述代碼為例:
//Try to use parameter in alert(), will fail
var name = "Bob";
var years = 42;
alert("%s is %d years old.", name, years);
如果alert()函數(shù)接受字符串傳參,那么預(yù)期的輸出結(jié)果將會是”Bob is 42 years old.”;但實際上alert()函數(shù)并不支持這么做,因此最終的輸出結(jié)果為”%s is %d years old.”。
彈出窗口樣式
由于alert()函數(shù)所使用的彈出框是瀏覽器系統(tǒng)對象而不是網(wǎng)頁文檔對象,因此無法通過在alert()函數(shù)中使用HTML標(biāo)簽來定義彈出框的樣式 — HTML標(biāo)簽將會被原封不動的進行顯示。對于以下代碼:
//Try to use HTML tags in alert(), will fail
alert("<b>Test Text</b>");
輸出結(jié)果并不是加粗的”Test Text”。
如果確實需要改變警示框的樣式,可以有以下兩種方案:
1.在alert()函數(shù)中使用Unicode字符。這種方案的好處是實現(xiàn)起來非常簡單,但其局限性也很明顯:Unicode字符的表現(xiàn)力非常有限。
2.不使用alert()函數(shù),轉(zhuǎn)而用HTML組件模擬彈出框(比如使用jQuery UI Dialog)。這種方案的優(yōu)勢是彈出框的表現(xiàn)力會很強,但對其的使用會增加前端代碼的復(fù)雜度。
結(jié)語
alert()函數(shù)可以用來向用戶警示信息,也可以用來調(diào)試程序。對于前者,使用jQuery UI Dialog等組件能大幅增加表現(xiàn)力及用戶體驗;而對于后者,由于alert()彈出框會阻斷JavaScript代碼的執(zhí)行,因此在很多情況下,使用console.log()來對程序進行調(diào)試是一種更好的方案。
相關(guān)文章
用正則xmlHttp實現(xiàn)的偷(轉(zhuǎn))
用正則xmlHttp實現(xiàn)的偷(轉(zhuǎn))...2007-01-01JS字符串累加Array不一定比字符串累加快(根據(jù)電腦配置)
言歸正傳:性能差異較大的機器運行結(jié)果會RT 出現(xiàn)大的差異,為了保險起見。還是推薦使用Array 來進行字符串拼接操作2012-05-05JS控件bootstrap datepicker使用方法詳解
這篇文章主要介紹了js控件bootstrap datepicker的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-03-03JavaScript函數(shù)式編程(Functional Programming)組合函數(shù)(Composition)用法分析
這篇文章主要介紹了JavaScript函數(shù)式編程(Functional Programming)組合函數(shù)(Composition)用法,結(jié)合實例形式分析了javascript函數(shù)式編程中組合函數(shù)的概念、原理、用法及操作注意事項,需要的朋友可以參考下2019-05-05