addLoadEvent方法解析
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方法解析相关推荐
- Peer J:整合高通量绝对丰度定量方法解析土壤细菌群落及动态
本文转自"上海天昊生物",已获授权 英文题目: Assessing soil bacterial community and dynamics by integrated high ...
- leaq c 汇编语言,汇编语言lea指令使用方法解析
这篇文章主要介绍了汇编语言lea指令使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 lea指令变种(按大小分类): leaw #2个字节 ...
- python类中方法的执行顺序-浅谈Python的方法解析顺序(MRO)
方法解析顺序, Method Resolution Order 从一段代码开始 考虑下面的情况: class A(object): def foo(self): print('A.foo()') cl ...
- 【Android NDK 开发】JNI 方法解析 ( 字符串数组参数传递 | 字符串遍历 | 类型强转 | Java 字符串与 C 字符串转换 | 字符串释放 )
文章目录 I . C/C++ 中的 Java 字符串数组类型 II . 获取字符串数组长度 III . 获取字符串数组元素 IV . 类型强转 ( jobject -> jstring ) V ...
- 【Android NDK 开发】JNI 方法解析 ( JNIEnv *env 参数 )
文章目录 一. JNI 方法解析 二. JNIEnv *env 参数解析 三. C 语言 环境中 JNIEnv *env 参数解析 四. C ++ 环境中 JNIEnv *env 参数解析 总结 : ...
- 【Android 多媒体开发】 MediaPlayer 状态机 接口 方法 解析
作者 : 韩曙亮 转载请著名出处 : http://blog.csdn.net/shulianghan/article/details/38487967 一. MediaPlayer 状态机 介绍 ...
- python不定长参数怎么相加_python函数不定长参数使用方法解析
这篇文章主要介绍了python函数不定长参数使用方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下 pathon中的函数可以使用不定长参数,可以 ...
- java修改文件的大小限制_Struts2修改上传文件大小限制方法解析
首先struts上传最大大小由两个地方决定. struts.multipart.maxSize决定整个post的form最大是多大,所以这个限制是最初的.默认大小是接近2M,在struts的defau ...
- java list 删除 遍历_Java list利用遍历进行删除操作3种方法解析
Java list利用遍历进行删除操作3种方法解析 这篇文章主要介绍了Java list利用遍历进行删除操作3种方法解析,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需 ...
最新文章
- 告别 Navicat ,同事安利的这个IDEA的兄弟,真香!
- “你要是有这个功能就好了!”
- String类的特点和使用步骤
- c语言江宝钏实验六答案,C语言程序设计江宝钏著实验六答案
- gitignore不起作用
- PaperNotes(19)-Learning Lane Graph Representations for Motion Forecasting
- 水滴公司启动医务社工高级人才培养计划
- Blazor 服务器上带有 EF Core 的 Azure Cosmos DB
- 10秒钟搞定圆柱齿轮设计所有课题
- 边缘增强算法MATLAB,基于MATLAB的图像增强算法研究及实现
- 这绝对是目前最好用的电脑桌面便签,免费的,墙裂推荐
- [转]音乐天堂 Music Heaven Vol.1 ~ Vol.36 的目录
- 多线程设计模式-主仆模式
- Hackintosh(黑苹果)bigsur (opencore引导)超级详细教程
- 阿里云国际版查看云服务器ecs实例系统日志和截图-Unirech
- C++算法设计与分析课后习题(第三章)
- 用户获取pppd拨号状态_iPhone手机隐藏的拨号键代码,原来还能这么用,幸好钱没白花...
- python 简历处理_利用python处理简历和名单——处理excel os、shutil处理文件
- 唯一历经五朝的皇妃,其印鉴藏于天津博物馆
- PG14新特性--恢复和VACUUM的加速
热门文章
- schedule调用相关整理
- hash算法_阿里面试官:讲一下Hashmap中hash算法!
- http传输字符编码与转义(深度好文)
- linux 脚本 if then,shell学习之if-then语法
- scala集合基本介绍
- python tableview 自适应_iOS8下UITableView的contentsize自动变化问题
- 最全的TCP面试知识点
- Linux基础——Linux 基本指令 nano 和 cat
- 机器学习——KNN及代码实现
- 安装Caffe报错:/usr/local/cuda-10.1/targets/x86_64-linux/lib/libcudnn.so.7 is not a symbolic link