亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js放到head中失效的原因與解決方法

 更新時(shí)間:2017年03月07日 15:47:48   作者:yangzailu1990  
本文主要介紹了js放到head中有時(shí)候會(huì)失效的原因以及解決方法,具有很好的參考價(jià)值。下面跟著小編一起來看下吧

1.今天寫js碰到一個(gè)奇怪的問題,寫好的js放到body里面執(zhí)行,但是放到head中沒有任何效果,為什么導(dǎo)致這種原因呢?

看失效代碼:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <title> new document </title>
 <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
 <style type="text/css">
 .login{width:40px;height:25px;line-height:25px;background-color:#4E74A5;margin-top:30px;text-align:center;color:#FFF;}
 </style>
 <script type="text/javascript" src="jquery-1.7.1.min.js"></script>
 <script type="text/javascript">
 $(".login").click(function(){
   alert(1);
   });
 </script>
 </head>
 <body>
 <input type="text" class="pass" />
 <div id="enter" class="login"> 登錄</div>
 </body>
</html>

2.解決辦法:把js代碼放到body中,或者利用 window.onload = function(){} 代碼包裹,文檔加載之后再執(zhí)行,以后不建議放到head中。

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <title> new document </title>
 <meta http-equiv="Content-Type" content="text/html;charset=UTF-8" />
 <style type="text/css">
 .login{width:40px;height:25px;line-height:25px;background-color:#4E74A5;margin-top:30px;text-align:center;color:#FFF;}
 </style>
 <script type="text/javascript" src="jquery-1.7.1.min.js"></script>
 <script type="text/javascript">
 window.onload = function(){
 $(".login").click(function(){
   alert(1);
   });
 } 
 </script>
 </head>
 <body>
 <input type="text" class="pass" />
 <div id="enter" class="login"> 登錄</div>
 </body>
</html>

3.原因:

因?yàn)槲臋n還沒加載,就讀了js,js就不起作用了想在head里用的話,用window.onload = function(){//這里包裹你的代碼}

js可以分為外部的和內(nèi)部的,外部的js一般放到head內(nèi)。內(nèi)部的js也叫本頁面的JS腳本,內(nèi)部的js一般放到body內(nèi),這樣做的目的有很多:

1.不阻塞頁面的加載(事實(shí)上js會(huì)被緩存)。

2.可以直接在js里操作dom,這時(shí)候dom是準(zhǔn)備好的,即保證js運(yùn)行時(shí)dom是存在的。

3.建議的方式是放在頁面底部,監(jiān)聽window.onload 或 readystate 來觸發(fā)js。

4.延伸:

head內(nèi)的js會(huì)阻塞頁面的傳輸和頁面的渲染。head 內(nèi)的 JavaScript 需要執(zhí)行結(jié)束才開始渲染 body,所以盡量不要將 JS 文件放在 head 內(nèi)。可以選擇在 document 完成時(shí),或者特定區(qū)塊后引入和執(zhí)行 JavaScript。head 內(nèi)的 JavaScript 需要執(zhí)行結(jié)束才開始渲染 body,所以盡量不要將 JS 文件放在 head 內(nèi)??梢赃x擇在 document 完成時(shí),或者特定區(qū)塊后引入和執(zhí)行 JavaScript。

所以在head內(nèi)的js一般要先執(zhí)行完后,才開始渲染body頁面。為了避免head引入的js腳本阻塞流浪器中主解析引擎對(duì)dom的解析工作,對(duì)dom的渲染,一般原則是,樣式在前面,dom文檔,腳本在最后面。遵循先解析再渲染再執(zhí)行script這個(gè)順序。

以上就是本文的全部?jī)?nèi)容,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時(shí)也希望多多支持腳本之家!

相關(guān)文章

  • JS嚴(yán)格模式原理與用法實(shí)例分析

    JS嚴(yán)格模式原理與用法實(shí)例分析

    這篇文章主要介紹了JS嚴(yán)格模式原理與用法,結(jié)合實(shí)例形式分析了JS嚴(yán)格模式基本概念、原理、用法及相關(guān)操作注意事項(xiàng),需要的朋友可以參考下
    2020-04-04
  • Js可拖拽放大的層拖動(dòng)特效實(shí)現(xiàn)方法

    Js可拖拽放大的層拖動(dòng)特效實(shí)現(xiàn)方法

    這篇文章主要介紹了Js可拖拽放大的層拖動(dòng)特效實(shí)現(xiàn)方法,涉及javascript操作DOM元素及css樣式的技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下
    2015-02-02
  • vant倒序年月日期組件封裝實(shí)例詳解

    vant倒序年月日期組件封裝實(shí)例詳解

    這篇文章主要介紹了vant倒序年月日期組件封裝實(shí)例詳解,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧
    2024-03-03
  • js讀取被點(diǎn)擊次數(shù)的簡(jiǎn)單實(shí)例(從數(shù)據(jù)庫中讀取)

    js讀取被點(diǎn)擊次數(shù)的簡(jiǎn)單實(shí)例(從數(shù)據(jù)庫中讀取)

    這篇文章主要介紹了js讀取被點(diǎn)擊次數(shù)的簡(jiǎn)單實(shí)例(從數(shù)據(jù)庫中讀取)。需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-03-03
  • CSS3+JavaScript實(shí)現(xiàn)翻頁幻燈片效果

    CSS3+JavaScript實(shí)現(xiàn)翻頁幻燈片效果

    這篇文章主要介紹了CSS3+JavaScript實(shí)現(xiàn)翻頁幻燈片效果,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-06-06
  • OpenLayer實(shí)現(xiàn)自定義坐標(biāo)點(diǎn)的繪制

    OpenLayer實(shí)現(xiàn)自定義坐標(biāo)點(diǎn)的繪制

    OpenLayers?是一個(gè)專為Web?GIS?客戶端開發(fā)提供的JavaScript?類庫包,用于實(shí)現(xiàn)標(biāo)準(zhǔn)格式發(fā)布的地圖數(shù)據(jù)訪問。本文將利用OpenLayer實(shí)現(xiàn)自定義坐標(biāo)點(diǎn)的繪制,感興趣的可以了解一下
    2022-04-04
  • 利用Echarts如何實(shí)現(xiàn)多段圓環(huán)圖

    利用Echarts如何實(shí)現(xiàn)多段圓環(huán)圖

    這篇文章主要給大家介紹了關(guān)于利用Echarts如何實(shí)現(xiàn)多段圓環(huán)圖的相關(guān)資料,文中通過實(shí)例代碼代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • KnockoutJS 3.X API 第四章之事件event綁定

    KnockoutJS 3.X API 第四章之事件event綁定

    event綁定即為事件綁定,即當(dāng)觸發(fā)相關(guān)DOM事件的時(shí)候回調(diào)函數(shù),這篇文章主要介紹了KnockoutJS 3.X API 第四章之事件event綁定的相關(guān)知識(shí),感興趣的朋友一起看看吧
    2016-10-10
  • js Array.slice的8種不同用法示例

    js Array.slice的8種不同用法示例

    這篇文章主要給大家介紹了關(guān)于js Array.slice的8種不同用法,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家學(xué)習(xí)或者使用js 具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • JS異步編程Promise對(duì)象詳解

    JS異步編程Promise對(duì)象詳解

    本文詳細(xì)講解了JS異步編程之Promise對(duì)象,文中通過示例代碼介紹的非常詳細(xì)。對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2022-06-06

最新評(píng)論