js的延遲執(zhí)行問(wèn)題分析
看這段代碼:
<body> <script src="deffer.js"></script> content </body>
deffer.js的內(nèi)容為:
alert(1)
這樣在alert窗口沒(méi)有被關(guān)閉之前,頁(yè)面都會(huì)是一片空白。因?yàn)閍lert窗口阻止了頁(yè)面的繼續(xù)渲染。
為了避免此類問(wèn)題,html規(guī)范里定義了deffer和async屬性,這兩個(gè)屬性的具體定義這里不討論,反正他們都是用來(lái)告訴瀏覽器,一定要在頁(yè)面渲染完成以后再執(zhí)行本腳本的內(nèi)容,這樣腳本執(zhí)行的時(shí)候頁(yè)面已經(jīng)渲染完畢了。
<body> <script deffer async src="deffer.js"></script> content </body>
注意,對(duì)于多個(gè)加了deffer或者async的腳本,他們的執(zhí)行順序和他們?cè)陧?yè)面上出現(xiàn)的順序無(wú)關(guān)。即使html規(guī)范定義了deffer腳本應(yīng)該按照順序來(lái)執(zhí)行,但是瀏覽器事實(shí)上并沒(méi)有全部遵守這個(gè)約定。
相關(guān)文章
layui form.render(''select'', ''test2'') 更新渲染的方法
今天小編就為大家分享一篇layui form.render('select', 'test2') 更新渲染的方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2019-09-09
js實(shí)現(xiàn)拉伸拖動(dòng)iframe的具體代碼
這篇文章介紹了js實(shí)現(xiàn)拉伸拖動(dòng)iframe的具體代碼,有需要的朋友可以參考一下2013-08-08
bootstrapValidator.min.js表單驗(yàn)證插件
這篇文章主要為大家詳細(xì)介紹了bootstrapValidator.min.js表單驗(yàn)證插件的使用方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02

