把多个JavaScript函数绑定到onload事件处理函数上的技巧

时间:2023-03-09 00:31:59
把多个JavaScript函数绑定到onload事件处理函数上的技巧

一,onload事件发生条件

  用户进入页面且页面所有元素都加载完毕。如果在页面的初始位置添加一个JavaScript函数,由于文档没有加载完毕,DOM不完整,可能导致函数执行错误或者达不到我们想要的效果。

二,绑定多个函数到onload事件上

1,先展示一个错误的做法

 window.onload = firstFunction;
window.onload = secondFunction;

实际执行过程中,只有最后一个函数被执行,因为每个事件处理函数只能绑定一条指令。

2,使用一个匿名函数

 window.onload = function()
{
firstFunction();
secondFunction();
}

3,一个通用的解决方案

  函数名称为addLoadEvent,它由Simon Willision编写,参数为页面执行完毕时需要执行的函数名字。

 function addLoadEvent(func)
{
var oldonload = window.onload;
if(typeof window.onload != 'function')
{
window.onload = func;
}
else
{
window.onload = function()
{
oldonload();
func();
}
}
}

如果window.onload没有进行任何赋值操作,window.onload返回的是一个object,进行赋值之后,返回function。  

这个函数的优点在于无论有多少个需要执行的函数,我只需加上一条语句就可以搞定,而无须修改以前的代码。

     addLoadFunction(firstFunction);
addLoadFunction(secondFunction);