Search

与我们合作

我们专注:网站策划设计、网络多媒体传播、网站优化及网站营销、品牌策略与设计
主营业务:网站建设、移动端微信小程序开发、VI设计、网络运营、云产品·运维解决方案

有一个品牌项目想和我们谈谈吗?

您可以填写右边的表格,让我们了解您的项目需求,这是一个良好的开始,我们将会尽快与您取得联系。当然也欢迎您给我们写信或是打电话,让我们听到您的声音

您也可通过下列途径与我们取得联系:

地 址: 深圳.龙岗区大运软件小镇11栋3楼

电 话: 138 2888 4598 / 138 0880 9053

网 址: http://www.appvx.cn

快速提交您的需求 ↓

Jquery加载顺序之$(document).ready用法

时间:2016-12-02 浏览:4400 编辑:网站设计前端伍林 来源:程序建站书籍

我们经常用js做网页特效,或者用js增添一些功能,那么你有没有遇到过在js正确的情况下实现不了它所应有的效果呢?对于经常折腾网页代码的人来说,是一定会有这种经验的,js代码没有错误,但是却不执行。因为我们忽略了网页在浏览器加载是有顺序规则的,包括html,css,js以及三者混合页面。今天着重说说$(document).ready(function(){})的用法,在jq中这一句等同于jquery(document).ready(function(){})也等同于$(function(){})。

举个例子:有时候我们在js文件中直接用

function juli(){

var tags = $("#footer");....//功能函数

}

juli();

写功能函数,然后我们在网页头部加载这个js文件,就会出现效果不出来的现象,原因在于当浏览器加载这个js文件的内容的时候,#footer这个id在网页后面,还在就绪阶段,还没加载也即不存在#footer,当这个js读不到这个id的时候自然就不能成功给#footer添加功能。

而解决办法除了把这个js放在网页最后加载之外,还有一个办法就是通过$(document).ready(function(){})包住,这样就可以解决加载顺序造成的错误。如:

$(document).ready(function(){

function juli(){

var tags = $("#footer");....//功能函数

}

juli();

});

因为$(document).ready(function(){})里面的内容是规定在DOM(网页文档)加载完成之后网页内容加载之前再执行的,也许很难理解,可以理解成html加载完成之后,图片加载之前。当所有id都加载完成之后再去查找#footer这样就能找到了,既可以完成js的功能实现。


阅读延伸:

跟$(document).ready(function(){})类似的还有原生js的windows.onload(),如:

window.onload=function(){

alert("深正互联");

}

window.onload()与$(document).ready(function(){})类似但又不同,window.onload()是在页面所有元素(包括图片,引用文件)加载完后才执行,既整个页面所有东西都加载完成后再加载。

跟window.onload()和$(document).ready(function(){})类似还有body.onload,这个加载顺序等同于windows.onload,只不过这个写在html的body标签上。如:<BODY onload="alert('body onload');alert(document.getElementById('testdiv').innerText)" onclick="alert('深正互联');">

好网站建设公司

本站文章均为深正网站建设摘自权威资料,书籍,或网络原创文章,如有版权纠纷或者违规问题,请即刻联系我们删除,我们欢迎您分享,引用和转载,但谢绝直接搬砖和抄袭!感谢...
GO 欣赏案例
查看经典案例
在线咨询
电话咨询
0755-36630177
返回顶部
在线咨询 获取报价 电话咨询
获取报价
您的称呼:

*

您的电话:

*

您的邮箱:

*

提交 重置
重要的事情,电话里聊

接通客服

不方便的时候线上咨询,在线等哦