js 有什么页面加载之后的事件

JavaScript017

js 有什么页面加载之后的事件,第1张

1在test.html页面,使用function创建一个myfun函数,代码如下:

2、在myfun函数内,使用alert()方法弹出“myfun函数执行了”的文字提示,代码如下。

3、在test.html中的body标签后面,使用onload在页面打开时就加载执行myfun()函数。

4、onload事件不仅可以放在body标签内,也可以直接在js标签内使用,代码如下。

5、在浏览器中打开test.html页面,结果如下。

在Jquery里面,我们可以看到两种写法:$(function(){})

和$(document).ready(function(){})

这两个方法的效果都是一样的,都是在dom文档树加载完之后执行一个函数(注意,这里面的文档树加载完不代表全部文件加载完)。

而window.onload是在dom文档树加载完和所有文件加载完之后执行一个函数。也就是说$(document).ready要比window.onload先执行。

那么Jquery里面$(document).ready函数的内部是怎么实现的呢?下面我们就来看看:

我们来为document添加一个ready函数:

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('onreadytstatechange',

function

()

{

if

(document.readyState

==

"complete")

{

document.detachEvent("onreadystatechange",

arguments.callee)

callback()

}

})

}

else

if

(document.lastChild

==

document.body)

{

callback()

}

}

document.ready这个函数是实现了。我们再来验证一下最上面所说的“ready要比onload先执行”:

window.onload

=

function

()

{

alert('onload')

}

document.ready(function

()

{

alert('ready')

})

执行这段代码之后,你会看到浏览器里面会先弹出“ready”,在弹出onload。

这个大家还是亲手试试吧!

=============================

以上来信息源于百度搜索。。。总的来说ready比onload要先触发