麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 編程 > JavaScript > 正文

如何讓頁面加載完成后執(zhí)行js

2019-11-20 22:36:37
字體:
供稿:網(wǎng)友

在很多情況下,js代碼需要設(shè)置為在頁面加載之后才去執(zhí)行,如果在頁面沒有加載完畢就執(zhí)行js代碼,很容易出現(xiàn)報錯情況,因?yàn)轫撁嬷械哪承ヾom根本沒有加載完畢。本文章向大家介紹如何讓js腳本在頁面加載完后再執(zhí)行的幾種方法。需要的朋友可以參考一下。

javascript 當(dāng)頁面dom模型加載完成后才執(zhí)行javascript

不能使用<body onload="">

加上 defer 等于在頁面完全在入后再執(zhí)行,相當(dāng)于 window.onload ,但應(yīng)用上比 window.onload 更靈活

<!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><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><title>無標(biāo)題文檔</title></head><body><script defer="defer">alert("頁面加載完我才執(zhí)行的")</script>先看到這段話 然后再執(zhí)行上面的 JS 如果去掉上面的 defer="defer" 那么會先執(zhí)行JS 在看到這段話</body></html>

方法1:使用defer

<script defer="defer" language="javascript"></script>
//或者
<script defer language="javascript"></script>

但這種方法只有IE支持,其他瀏覽器不識別defer 這種方法不靠譜
 
方法2:window.onload

<script type=”text/javascript”>window.onload=function (){  var userName=”xiaoming”;  alert(userName);}</script>

但這個方法在IE中只能在一個地方調(diào)用,假如2個地方調(diào)用,后面調(diào)用的就會把前面的添加的覆蓋掉; 

方法3:jQuery方法,需要引用jQuery文件。

<script type=”text/javascript”>$(document).ready(function (){  var userName=”xiaoming”;  alert(userName);});</script>

下面我們介紹一下Window.onload=function (){}與$(document).ready(function (){})的區(qū)別:
在Jquery里面,我們可以看到兩種寫法:$(function(){}) 和$(document).ready(function(){})
這兩個方法的效果都是一樣的,都是在dom文檔樹加載完之后執(zhí)行一個函數(shù)(注意,這里面的文檔樹加載完不代表全部文件加載完)。
而window.onload是在dom文檔樹加載完和所有文件加載完之后執(zhí)行一個函數(shù)。也就是說$(document).ready要比window.onload先執(zhí)行。
那么Jquery里面$(document).ready函數(shù)的內(nèi)部是怎么實(shí)現(xiàn)的呢?下面我們就來看看:
我們來為document添加一個ready函數(shù):

document.ready = function (callback) {      ///兼容FF,Google      if (document.addEventListener) {        document.addEventListener('DOMContentLoaded', function () {          document.removeEventListener('DOMContentLoaded', arguments.callee, false);          callback();        }, false)      }       //兼容IE      else if (document.attachEvent) {        document.attachEvent('onreadystatechange', function () {           if (document.readyState == "complete") {                document.detachEvent("onreadystatechange", arguments.callee);                callback();            }        })      }      else if (document.lastChild == document.body) {        callback();      }    }

document.ready這個函數(shù)是實(shí)現(xiàn)了。我們再來驗(yàn)證一下最上面所說的“ready要比onload先執(zhí)行”:

window.onload = function () {      alert('onload');    };    document.ready(function () {      alert('ready');    });

執(zhí)行這段代碼之后,你會看到瀏覽器里面會先彈出“ready”,在彈出onload。
這個大家還是親手試試吧!

發(fā)表評論 共有條評論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 日韩一级免费毛片 | 在线成人免费视频 | 欧美性受xxxxxx黑人xyx性爽 | 九九精品在线 | 性aaa| 国产免费一级淫片a级中文 99国产精品自拍 | 精品一区二区三区在线观看视频 | 久久免费精品视频 | 91av大片| 三级国产三级在线 | 国产第一页精品 | 91精品国产乱码久久久久久久久 | 国语自产免费精品视频在 | 国产精品成人久久久久a级 av电影在线免费 | 91看片淫黄大片欧美看国产片 | 亚洲午夜视频 | 爱草在线 | 国产免费高清 | 欧美精品18videos性欧美 | hdhdhd69ⅹxxx黑人 | 羞羞网站入口 | 欧美一区二区三区久久精品视 | 亚洲国产精品高潮呻吟久久 | 91精品国产成人 | 久久久婷婷一区二区三区不卡 | 亚洲aⅴ免费在线观看 | 九九热视频免费在线观看 | 亚洲精品一区二区三区大胸 | 国产九色视频在线观看 | 亚洲影视中文字幕 | 免费在线观看中文字幕 | 免费黄色欧美视频 | 免费午夜视频在线观看 | 免费a观看 | 91精品动漫在线观看 | 欧美中文在线 | 麻豆小视频在线观看 | xxxxxx打针视频vk | 国产婷婷一区二区三区 | 99日韩精品视频 | 国产亚洲欧美日韩高清 |