onload方法在网页加载完毕时,会自动执行,但是该方法有个缺点就是只能执行一个方法。

  onload的限制

  比如下面的代码:

        <script type="text/javascript">function func1(){console.log("this is func1()");}function func2(){console.log("this is func2()");}window.onload = func1;window.onload = func2;</script>

  执行结果如下:

  只有第二个方法被执行。

  那么如何才能在页面加载完成后,执行多个方法呢?

  可以采用addLoadEvent方法,这个方法是由其他人编写的,所以不是DOM里面的方法,如果使用直接复制下面这段代码就可以了!

            function addLoadEvent(func){var oldonload = window.onload;if(typeof window.onload != 'function'){console.log("addLoadEvent第一次执行!");window.onload = func;}else{console.log("addLoadEvent多次执行!");window.onload = function(){oldonload();func();}}}

  有了这段代码,就可以给onload绑定多个方法:

            function func1(){console.log("this is func1()");}function func2(){console.log("this is func2()");}addLoadEvent(func1);addLoadEvent(func2);

  原理如同:

            window.onload = function(){func1();func2();}

  下面看一下执行的结果:

  完美达到目的!

  代码解析

  虽然只有几行代码,但是第一次接触的时候,难免晕头转向!

  仔细阅读下面的代码:

            function addLoadEvent(func){var oldonload = window.onload;if(typeof window.onload != 'function'){console.log("addLoadEvent第一次执行!");window.onload = func;}else{console.log("addLoadEvent多次执行!");window.onload = function(){oldonload();func();}}}

  这个方法需要一个参数func,就是传入的方法名称。

  当我们使用一次addLoadEvent的时候,就相当于调用window.onload = func1;

  此时window.onload应该是null,因此判断语句typeof window.onload != 'function' 就会返回true.

  执行后,可以看到window.onload方法变成了func1:

  

  再次调用addLoadEvent时,进入else的部分。把func2与原来的oldonload方法一同绑定成新的方法。

  执行后,看到window.onload方法变成如下的样子:

  

  以此类推,当有多个方法时,就会构造出如下的方法:

window.onload = function(){func1();func2();...func10000();
}

  这样就可以在onload时,绑定多个方法了。

  总结起来,该方法就是把 所有想要在onload时期执行的方法 构造成一个 方法的执行对列 ,然后使用onload执行这个 队列方法

  参考

  【1】addLoadEvent(func)详解:http://www.cnblogs.com/joyan/archive/2010/06/29/1767577.html

  【2】脚本之家addLoadEvent说明:http://www.jb51.net/article/21707.htm

转载于:https://www.cnblogs.com/xing901022/p/4344972.html

addLoadEvent方法解析相关推荐

  1. Peer J:整合高通量绝对丰度定量方法解析土壤细菌群落及动态

    本文转自"上海天昊生物",已获授权 英文题目: Assessing soil bacterial community and dynamics by integrated high ...

  2. leaq c 汇编语言,汇编语言lea指令使用方法解析

    这篇文章主要介绍了汇编语言lea指令使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 lea指令变种(按大小分类): leaw #2个字节 ...

  3. python类中方法的执行顺序-浅谈Python的方法解析顺序(MRO)

    方法解析顺序, Method Resolution Order 从一段代码开始 考虑下面的情况: class A(object): def foo(self): print('A.foo()') cl ...

  4. 【Android NDK 开发】JNI 方法解析 ( 字符串数组参数传递 | 字符串遍历 | 类型强转 | Java 字符串与 C 字符串转换 | 字符串释放 )

    文章目录 I . C/C++ 中的 Java 字符串数组类型 II . 获取字符串数组长度 III . 获取字符串数组元素 IV . 类型强转 ( jobject -> jstring ) V ...

  5. 【Android NDK 开发】JNI 方法解析 ( JNIEnv *env 参数 )

    文章目录 一. JNI 方法解析 二. JNIEnv *env 参数解析 三. C 语言 环境中 JNIEnv *env 参数解析 四. C ++ 环境中 JNIEnv *env 参数解析 总结 : ...

  6. 【Android 多媒体开发】 MediaPlayer 状态机 接口 方法 解析

    作者 : 韩曙亮 转载请著名出处 :  http://blog.csdn.net/shulianghan/article/details/38487967 一. MediaPlayer 状态机 介绍 ...

  7. python不定长参数怎么相加_python函数不定长参数使用方法解析

    这篇文章主要介绍了python函数不定长参数使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 pathon中的函数可以使用不定长参数,可以 ...

  8. java修改文件的大小限制_Struts2修改上传文件大小限制方法解析

    首先struts上传最大大小由两个地方决定. struts.multipart.maxSize决定整个post的form最大是多大,所以这个限制是最初的.默认大小是接近2M,在struts的defau ...

  9. java list 删除 遍历_Java list利用遍历进行删除操作3种方法解析

    Java list利用遍历进行删除操作3种方法解析 这篇文章主要介绍了Java list利用遍历进行删除操作3种方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需 ...

最新文章

  1. 告别 Navicat ,同事安利的这个IDEA的兄弟,真香!
  2. “你要是有这个功能就好了!”
  3. String类的特点和使用步骤
  4. c语言江宝钏实验六答案,C语言程序设计江宝钏著实验六答案
  5. gitignore不起作用
  6. PaperNotes(19)-Learning Lane Graph Representations for Motion Forecasting
  7. 水滴公司启动医务社工高级人才培养计划
  8. Blazor 服务器上带有 EF Core 的 Azure Cosmos DB
  9. 10秒钟搞定圆柱齿轮设计所有课题
  10. 边缘增强算法MATLAB,基于MATLAB的图像增强算法研究及实现
  11. 这绝对是目前最好用的电脑桌面便签,免费的,墙裂推荐
  12. [转]音乐天堂 Music Heaven Vol.1 ~ Vol.36 的目录
  13. 多线程设计模式-主仆模式
  14. Hackintosh(黑苹果)bigsur (opencore引导)超级详细教程
  15. 阿里云国际版查看云服务器ecs实例系统日志和截图-Unirech
  16. C++算法设计与分析课后习题(第三章)
  17. 用户获取pppd拨号状态_iPhone手机隐藏的拨号键代码,原来还能这么用,幸好钱没白花...
  18. python 简历处理_利用python处理简历和名单——处理excel os、shutil处理文件
  19. 唯一历经五朝的皇妃,其印鉴藏于天津博物馆
  20. PG14新特性--恢复和VACUUM的加速

热门文章

  1. schedule调用相关整理
  2. hash算法_阿里面试官:讲一下Hashmap中hash算法!
  3. http传输字符编码与转义(深度好文)
  4. linux 脚本 if then,shell学习之if-then语法
  5. scala集合基本介绍
  6. python tableview 自适应_iOS8下UITableView的contentsize自动变化问题
  7. 最全的TCP面试知识点
  8. Linux基础——Linux 基本指令 nano 和 cat
  9. 机器学习——KNN及代码实现
  10. 安装Caffe报错:/usr/local/cuda-10.1/targets/x86_64-linux/lib/libcudnn.so.7 is not a symbolic link