js加载时双击

JavaScript027

js加载时双击,第1张

js加载时双击:

1、新建一个html文件,命名为test.html,

2、在test.html页面中,使用button标签创建一个按钮,用于下面双击该按钮时触发双击事件。

3、在test.html页面中,给button按钮绑定ondblclick双击事件,当按钮被双击时,执行go()函数。

4、在test.html页面中,使用script标签标记js代码执行区域,

5、在js内,使用function创建一个go()函数,

6、在go()函数内,使用alert()方法弹出文字内容,例如,弹出这是一个双击按钮文字。

7、在浏览器打开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要先触发