script元素
向HTML頁(yè)面中插入JavaScript的主要方法,就是使用<script>
元素
<script>
有以下6個(gè)屬性:
- async:可選 表示應(yīng)該立即下載腳本 但不妨礙頁(yè)面中的其他操作 只對(duì)外部腳本文件有效
- charset:可選 表示通過(guò)src屬性指定的代碼的字符集
- defer:可選 表示腳本可以延遲到文檔完全被解析和顯示之后再執(zhí)行 只對(duì)外部腳本有效
- language:已廢棄 用于表示編寫代碼使用的腳本語(yǔ)言
- src:可選 表示包含要執(zhí)行代碼的外部文件
- type:可選 表示編寫代碼使用的腳本語(yǔ)言的內(nèi)容類型
使用<script>
元素的方式: - 直接在頁(yè)面中嵌入JavaScript代碼
!注意 !:當(dāng)瀏覽器遇到字符串<\script>
時(shí)會(huì)認(rèn)為是結(jié)束的</script>
標(biāo)簽,因此在代碼中的某一地方出現(xiàn)這個(gè)字符串時(shí),瀏覽器在加載代碼時(shí)會(huì)產(chǎn)生錯(cuò)誤,如果真的要用的靴跛,也必須通過(guò)轉(zhuǎn)義字符“\”來(lái)解決,寫成```</script> - 包含外部JavaScript文件
渡嚣!注意 I揖Α:通過(guò)<script>
元素來(lái)包含外部js文件,那么src屬性就是必須的严拒,這個(gè)屬性的值是一個(gè)指向外部js文件的鏈接
在html網(wǎng)頁(yè)中外部文件的src屬性只需包含在<script>和</script>
代碼之間扬绪,就可以成功引用到這個(gè)外部js文件
在xhtml文檔中,可以省略</script>
標(biāo)簽裤唠,但在html文檔中不可以
帶有src屬性的<script>
元素不應(yīng)該在其開(kāi)始與結(jié)束標(biāo)簽之間再包含額外的js代碼挤牛,如果包含了嵌入的代碼,則只會(huì)下載并執(zhí)行外部腳本文件种蘸,嵌入的代碼會(huì)被忽略
src屬性可以是指向當(dāng)前html頁(yè)面所在域之外的某個(gè)域中的完整url墓赴,這樣位于外部域中的代碼也會(huì)被加載和解析航瞭,就想著寫代碼位于加載它們的頁(yè)面中一樣
無(wú)論如何包含代碼诫硕,只要不存在defer和async屬性,瀏覽器都會(huì)按js文件出現(xiàn)的先后順序依次進(jìn)行解析
標(biāo)簽位置
按傳統(tǒng)做法 所有<script>
元素都應(yīng)該放在頁(yè)面的<head>
元素中
這種做法的目的是把所有外部文件的引用都放在相同的地方
但缺點(diǎn)是必須等到全部js代碼都被下載刊侯、解析和執(zhí)行完成之后章办,才能開(kāi)始呈現(xiàn)頁(yè)面的內(nèi)容,因此在有很多js代碼的頁(yè)面來(lái)說(shuō),有極大可能會(huì)導(dǎo)致瀏覽器在呈現(xiàn)頁(yè)面時(shí)出現(xiàn)明顯的延遲
因此藕届,為了避免這個(gè)問(wèn)題挪蹭,現(xiàn)代Web應(yīng)用程序一般都把全部js引用放在<body>
元素中頁(yè)面內(nèi)容的后面
這樣做的優(yōu)點(diǎn)是在解析包含的js代碼之前,頁(yè)面的內(nèi)容將完全呈現(xiàn)在瀏覽器中休偶,而用戶也會(huì)因?yàn)闉g覽器窗口顯示空白頁(yè)面的時(shí)間縮短而感到打開(kāi)頁(yè)面的速度加快
defer延遲腳本
在<script>
元素中設(shè)置defer屬性梁厉,相當(dāng)于告訴瀏覽器立即下載,但延遲執(zhí)行
延遲執(zhí)行的腳本在瀏覽器遇到</html>
時(shí)會(huì)執(zhí)行
如果有多個(gè)延遲執(zhí)行的腳本踏兜,HTML5規(guī)范要求腳本們按照出現(xiàn)的先后順序依次執(zhí)行词顾,但現(xiàn)實(shí)中,并不一定會(huì)這樣碱妆,因此最好只包含一個(gè)延遲腳本肉盹,且把延遲腳本放在頁(yè)面底部是最佳選擇
defer屬性只適用于外部腳本文件
async異步腳本
只適用于外部腳本,并告訴瀏覽器立即下載文件
標(biāo)記為async的腳本并不保證按照指定它們的先后順序執(zhí)行
指定async屬性的目的是不讓頁(yè)面等待兩個(gè)腳本下載和執(zhí)行山橄,從而異步加載頁(yè)面其他內(nèi)容垮媒,因此建議異步腳本不要在加載期間修改DOM
異步腳本一定會(huì)在頁(yè)面的load事件前執(zhí)行,但可能會(huì)在DOMContentLoaded事件觸發(fā)之前或之后執(zhí)行
noscript元素
使用<noscript>
元素可以指定在不支持腳本的瀏覽器中顯示的代替內(nèi)容航棱,但在啟用了腳本的情況下,瀏覽器將不會(huì)顯示這個(gè)元素中的任何內(nèi)容