使用 Javascript
設(shè)計(jì)網(wǎng)頁需要注意代碼出現(xiàn)的順序以及是否將代碼封裝到函數(shù)或?qū)ο笾校羞@些都會(huì)影響代碼運(yùn)行的順序。想要掌握網(wǎng)頁設(shè)計(jì)最新的編程技能和知識(shí),建議參加web前端培訓(xùn),課程實(shí)時(shí)更新,緊跟企業(yè)需求,讓你輕松找到工作。
Javascript 網(wǎng)頁上的位置
由于頁面上的 Javascript 基于某些因素執(zhí)行,讓我們考慮在何處以及如何將 Javascript
添加到網(wǎng)頁?;旧衔覀兛梢栽谌齻€(gè)位置附加 Javascript:
直接進(jìn)入頁面頭部
直接進(jìn)入頁面正文
從事件處理程序/偵聽器
Javascript 是在網(wǎng)頁本身還是在鏈接到頁面的外部文件中沒有任何區(qū)別。 事件處理程序是硬編碼到頁面中還是由
Javascript 本身添加也無關(guān)緊要(除非它們?cè)谔砑又安荒鼙挥|發(fā))。
1. 直接在頁面上編碼
說 Javascript
直接在頁面的頭部或正文中是什么意思?如果代碼沒有包含在函數(shù)或?qū)ο笾?,則直接在頁面中。在這種情況下,只要包含代碼的文件已加載到足以訪問該代碼,代碼就會(huì)按順序運(yùn)行。
函數(shù)或?qū)ο笾械拇a僅在調(diào)用該函數(shù)或?qū)ο髸r(shí)運(yùn)行?;旧?,這意味著頁面頭部和正文中任何不在函數(shù)或?qū)ο髢?nèi)的代碼都將在頁面加載時(shí)運(yùn)行——只要頁面加載到足以訪問該代碼的程度。關(guān)于更多網(wǎng)頁設(shè)計(jì)的技巧,可以考慮通過參加web前端培訓(xùn)來學(xué)習(xí),有專業(yè)老師指導(dǎo),有全面系統(tǒng)的課程,學(xué)起來又快又輕松。
最后一點(diǎn)很重要,它會(huì)影響你在頁面上放置代碼的順序:任何直接放置在頁面中且需要與頁面中的元素交互的代碼都必須出現(xiàn)在它所依賴的頁面中的元素之后。一般來說,這意味著如果你使用直接代碼與頁面內(nèi)容進(jìn)行交互,則此類代碼應(yīng)放在正文的底部。
函數(shù)和對(duì)象中的代碼
每當(dāng)調(diào)用該函數(shù)或?qū)ο髸r(shí),就會(huì)運(yùn)行函數(shù)或?qū)ο笾械拇a。如果它是從直接位于頁面頭部或正文中的代碼調(diào)用的,那么它在執(zhí)行順序中的位置實(shí)際上就是從直接代碼調(diào)用函數(shù)或?qū)ο蟮狞c(diǎn)。
2. 分配給事件處理程序和偵聽器的代碼
將函數(shù)分配給事件處理程序或偵聽器不會(huì)導(dǎo)致函數(shù)在分配時(shí)運(yùn)行 - 前提是你實(shí)際上是在分配函數(shù)本身而不是運(yùn)行函數(shù)并分配返回的值。
(這就是為什么在將函數(shù)分配給事件時(shí)通??床坏胶瘮?shù)名稱末尾的 (),因?yàn)樘砑永ㄌ?hào)會(huì)運(yùn)行函數(shù)并分配返回的值,而不是分配函數(shù)本身。)
附加到事件處理程序和偵聽器的函數(shù)在它們附加到的事件被觸發(fā)時(shí)運(yùn)行。 大多數(shù)事件是由與你的頁面交互的訪問者觸發(fā)的。
但是,存在一些例外情況,例如窗口本身的 load 事件,該事件在頁面完成加載時(shí)觸發(fā)。如果你想學(xué)習(xí)
Javascript編程技巧,你可以從web前端培訓(xùn)課程開始,這是一個(gè)很好的起點(diǎn)和開始。
附加到頁面元素事件的函數(shù)
任何附加到頁面本身元素上的事件的函數(shù)都將根據(jù)每個(gè)訪問者的操作運(yùn)行 - 此代碼僅在發(fā)生特定事件以觸發(fā)它時(shí)運(yùn)行。
出于這個(gè)原因,代碼是否永遠(yuǎn)不會(huì)為給定的訪問者運(yùn)行并不重要,因?yàn)樵撛L問者顯然沒有執(zhí)行需要它的交互。
當(dāng)然,所有這一切都假設(shè)你的訪問者使用啟用了Javascript的瀏覽器訪問了你的頁面。
3. 自定義訪客用戶腳本
一些用戶安裝了可能與你的網(wǎng)頁交互的特殊腳本。這些腳本在你的所有直接代碼之后運(yùn)行,但在附加到加載事件處理程序的任何代碼之前運(yùn)行。
由于你的頁面對(duì)這些用戶腳本一無所知,因此你無法知道這些外部腳本可能會(huì)做什么 -
它們可以覆蓋你附加到你分配處理的各種事件的任何或所有代碼。如果此代碼覆蓋事件處理程序或偵聽器,則對(duì)事件觸發(fā)器的響應(yīng)將運(yùn)行用戶定義的代碼,而不是運(yùn)行你的代碼,或者除了運(yùn)行你的代碼之外。
這里的要點(diǎn)是,你不能假設(shè)設(shè)計(jì)為在頁面加載后運(yùn)行的代碼將被允許按照你設(shè)計(jì)的方式運(yùn)行。此外,請(qǐng)注意,某些瀏覽器具有允許在瀏覽器中禁用某些事件處理程序的選項(xiàng),在這種情況下,相關(guān)事件觸發(fā)器將不會(huì)在你的代碼中啟動(dòng)相應(yīng)的事件處理程序/偵聽器。在web前端培訓(xùn)學(xué)習(xí)中,有很多關(guān)于
Javascript
設(shè)計(jì)網(wǎng)頁的課程,理論知識(shí)+實(shí)踐項(xiàng)目,雙管齊下,更有利于學(xué)員加深對(duì)所學(xué)知識(shí)的理解和運(yùn)用,真正做到學(xué)以致用,從而將知識(shí)內(nèi)化成自身的能力。