document.write的幾點使用心得
一直用document.write()方法向瀏覽器中顯示數(shù)據(jù)用,把它當(dāng)做Alert()使用, 看來這樣用有些大材小用了,下面說說它的主要用處。
document.write()方法可以用在兩個方面:
1.頁面載入過程中,用腳本加入新的頁面內(nèi)容。
2.用延時腳本創(chuàng)建本窗口或新窗口的內(nèi)容。
該方法需要一個字符串參數(shù),它是寫到窗口或框架中的HTML內(nèi)容。這些字符串參數(shù)可以是變量或值為字符串的表達式,寫入的內(nèi)容常常包括HTML標記語言。如下面代碼,教務(wù)系統(tǒng)框架載入子頁
<!--將框架放入單元格中-->
<span style="font-size:18px;">
<td class="index-table-middle-center" valign="top" id="content-container">
<div id="loading">
//加載效果圖標
<img src="images/loading.gif" alt="loading" border="0" />
</div>
<script type="text/javascript">
//調(diào)用JS的OutputIFrame函數(shù),形成框架
Index.OutputIframe();
</script>
</td>
</span>
<span style="font-size:18px;">//輸出框架
Index.OutputIframe = function () {
var scrolling = $.isIE6 == true ? 'yes' : 'auto';
document.write('<iframe id="content" width="100%" height="100%" class="hide" marginwidth="0" marginheight="0" frameborder="0" scrolling="' + scrolling + '" onload="$(\'#loading\').hide();$(this).show();" src=""></iframe>');
};
</span>
在載入頁面后,瀏覽器輸出流自動關(guān)閉。在此之后,任何一個對當(dāng)前頁面進行操作的document.write()方法將打開—個新的輸出流,它將清除當(dāng)前頁面內(nèi)容(包括源文檔的任何變量或值)。因此,假如希望用腳本生成的HTML替換當(dāng)前頁面,就必須把HTML內(nèi)容連接起來賦給一個變量,使用一個document.write()方法完成寫操作。
關(guān)于document.write()方法還有一點要說明的是它的相關(guān)方法document.close()。腳本向窗口(不管是本窗口或其他窗口)寫完內(nèi)容后,必須關(guān)閉輸出流。在延時腳本的最后一個document.write()方法后面,必須確保含有document.close()方法,不這樣做就不能顯示圖像和表單。并且,任何后面調(diào)用的document.write()方法只會把內(nèi)容追加到頁面后,而不會清除現(xiàn)有內(nèi)容來寫入新值。
為了演示document.write()方法,我們提供了同一個應(yīng)用程序的兩個版本。一個向包含腳本的文檔中寫內(nèi)容,另—個向—個單獨的窗口寫內(nèi)容。
示例1創(chuàng)建一個按鈕,它為文檔組合新的HTML內(nèi)容,包括新文檔標題的HTML標記和標記的顏色屬性。
示例中有一個讀者所不熟悉的操作符+=,它把其右側(cè)的字符串加到其左側(cè)的變量中,這個變量用來存放字符串,這個操作符能很方便地把幾個單獨的語句組合成—個長字符串。使用組合在newContent變量中的內(nèi)容document.write()語句可以把所有新內(nèi)容寫到文檔中,完全清除示例1中的內(nèi)容。
然后需要調(diào)用document.close()語句關(guān)閉輸出流。當(dāng)載入該文檔并單擊按鈕時,可以注意到瀏覽器標題欄中的文檔標題因此而改變。當(dāng)回到原始文檔并再次單擊該按鈕時,可以看到動態(tài)寫入的第二個頁面的載入速度甚至比重載原始文檔還要快。
示例1 在當(dāng)前窗口使用document.write()。
<html xmlns="http://www.w3.org/1999/xhtml"><title>Writing to Same Doc</title>
<script language="JavaScript">
//重新寫入函數(shù)
function RepeatWrite(){
// 保存寫入的內(nèi)容
var newContent = "<html><head><title>A New Doc</title></head>"
newContent += "<body bgcolor='aqua'><h1>This document is brand new.</h1>"
newContent += "Click the Back button to see original document."
newContent += "</body></html>"
// 寫入新的內(nèi)容
document.write(newContent);
document.close();
}
</script>
</head>
<body>
<form>
<!--單擊按鈕調(diào)用寫入函數(shù)-->
<input type="button" value="Replace Content" onClick="RepeatWrite()">
</form>
</body>
</html>
總結(jié):
最近在寫一個靜態(tài)資源加載器, 其中有用到document.write, 在經(jīng)歷過一翻折騰后, 發(fā)現(xiàn)document.write還是有點內(nèi)容的,所以決定折騰點東西記錄下,同時也算是給自己積累點東西.
相關(guān)文章
小程序開發(fā)中如何使用async-await并封裝公共異步請求的方法
在平常的項目開發(fā)中肯定會遇到同步異步執(zhí)行的問題,這篇文章主要介紹了小程序開發(fā)中如何使用async-await并封裝公共異步請求的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-01-01細說JavaScript中的this指向與綁定規(guī)則
本文主要詳細介紹了JavaScript中的this指向與綁定規(guī)則,默認綁定,隱式綁定,顯示綁定,new綁定這四個規(guī)則,文中有相關(guān)的代碼示例供大家參考,感興趣的同學(xué)可以閱讀下2023-05-05javascript下利用數(shù)組緩存正則表達式的實現(xiàn)方法
利用組存大法要提高我們程序的性能,讓我們的正則表達式的創(chuàng)建于執(zhí)行更有效率。2009-12-12javascript實現(xiàn)在網(wǎng)頁任意處點左鍵彈出隱藏菜單的方法
這篇文章主要介紹了javascript實現(xiàn)在網(wǎng)頁任意處點左鍵彈出隱藏菜單的方法,設(shè)計鼠標事件及css樣式操作的相關(guān)技巧,需要的朋友可以參考下2015-05-05