在给网页加一些特效时经常要在<body>中加入“onload”事件,即在网页加载完后执行某事件,例如:<body onload=”alert(‘欢迎光临!')”,但这样做有个大的缺陷,事件会在网页完全下载完后才会执行,包括网页中的图片或Flash等,如果网页中的图片比较大或有很多图,可能还没等网页完全下载完网友已经点击链接到其它网页去了,这样这个事件就没有执行了。另外在某些特殊情况下可能还修改不了网页的body参数。如在别人网站发表文章时,或用CMS整站系统时。
这时我们会想到用“window.onload”或“document.body.onload”来替换<body>中的onload事件,的确,问题解决了,但在加载多个onload事件时或控制加裁顺序时还会出现一些问题,直到我发现“Paul Koch”写的addLoadEvent()函数后,所有问题都解决了。如果大家一定要用“window.onload”或 “document.body.onload”来替换<body>中的onload事件,建议大家用前者,Firefox浏览器中无效,即兼容性有问题。
JavaScript代码
复制代码 代码如下:
function addLoadEvent(func) {
var oldonload = window.onload;
if (typeof window.onload != 'function') {
window.onload = func;
} else {
window.onload = function() {
oldonload();
func();
}
}
}
调用方法: 复制代码 代码如下:
addLoadEvent(wwwjb51());
//或
addLoadEvent(function(){
document.body.style.backgroundColor = 'yellow';
jb51();
});
演示代码:
[Ctrl+A 全选 注:引入外部Js需再刷新一下页面才能执行]
推荐大家以后都用addLoadEvent()函数来替换<body>中加入“onload”事件。addLoadEvent ()自定义代码来源于:http://www.simonwillison.net/2004/May/26/addLoadEvent/
addLoadEvent工作流程: 把现有的window.onload事件处理函数的值存入变量oldonload。
如果在这个处理函数上还没有绑定任何函数,就像平时那样把新函数添加给它;
如果在这个处理函数已经绑定了一些函数,就把函数追回到现有指令未尾。
浏览器加载html内容是自上而下的(默认),而JS一般是在哪里引入——想想如果JS里面包含了一些即时执行指令,
它会操作根本不存在元素节点(因为还没有加载完)会有什么后果?结果就是出错。
addLoadEvent可以实现无论有多少个函数,都能让它们同时和window.onload事件绑定。
onload事件-----addLoadEvent函数
复制代码 代码如下:
window.onload = myfunction();
假如我们希望某个函数在网页加载完毕之后就立即执行。网页加载完毕时会触发一个onload事件,所以我们可以利用onload事件来加载这个函数。Onload事件与window对象相关联。如:
把myfunction函数绑定到这个事件上:
一个函数我们可以利用上面的解决,那两个、三个甚至更多呢?怎么解决??
假如我们有firstFunction和secondFunction两个函数,是不是就是下面这样写呢:
复制代码 代码如下:
window.onload = firstFunction;
window.onload = secondFunction;
但是每个处理函数只能绑定一条指令。所以上面的不行。因为secondFunction函数将会取代firstFunction函数。
有一种办法可以帮助我们解决上面问题:即我们先创建一个匿名函数来容纳这两个函数,然后把那个匿名函数绑定到onload事件上,如下:
复制代码 代码如下:
window.onload = function(){
firstFunction();
secondFunction();
}
这确实是一个好的、简答的方法。
但是其实还存在一个最佳的解决方案——不管你打算在页面加载完毕后要执行多少个函数,利用该函数都可以轻松的实现。
该函数名为addLoadEvent。该函数仅一个参数:该参数指定了你打算在页面加载完毕后需要执行的函数的函数名。
addLoadEvent()函数代码如下:
复制代码 代码如下:
function addLoadEvent(func){
var oldonLoad = window.onload;
if(typeof window.onload!='function'){
window.onload = func;
}
else{
window.onload = function(){
oldonload();
func();
}
}
}
addLoadEvent函数主要是完成如下的操作:
1、把现有的window.onload事件处理函数的值存入到oldonload中。
2、如果在这个处理函数上还没有绑定任何函数,就将该函数添加给它。
3、如果在这个处理函数上已经绑定了一些函数,就把该函数追加到现有指定的末尾。
通过addLoadEvent函数,只需要调用该函数就可以进行绑定了。
复制代码 代码如下:
addLoadEvent(firestFunction);
addLoadEvent(secondFunction);
所以这个函数非常有用,尤其当代码变得很复杂的时候。无论你打算在页面加载完毕时执行多少个函数,只需要多写几条这样的语句就可以解决了。方便、实用。
相关推荐:
ChatGPT4账号共享-让AI助力你的学习与工作,轻松提升效率,ai巨无霸
WP原创:打造属于你的独特网站,从这里开始!,一个网站推广一个月需要多少钱
ChatGPT不能访问,我的学术水平直线下降,泰州大数据ai艾灸价格
自动写文章的AI,提升效率的创作利器
“赞片CMS”-让你的*站点管理更高效、便捷,日照seo平台
OpenAI注册问题解决方案:如何顺利通过手机号验证,反对ai头像
为什么“蜘蛛弛查询”能成为提升网站排名的秘密武器?,惠州网站推广v1戈seo24
SEO优化基础:让你的网站脱颖而出的秘密武器,模仿猫ai
SEO优化如何为网站做好关键词研究和优化,ai直通
怎么用AI写文:让创作更轻松,效率翻倍
SEO结构优化:助力网站提升排名与流量的关键策略,杭州小网站推广哪家好做
SEO搜索关键词是什么意思?全方位解析关键词优化的核心要素,lol ai图片
SEO联系:如何通过SEO优化提升您的网络营销效果,企业营销推广获客
AI网页设计生成-智能化创造无限可能,ai机甲风背景音乐
SEO适合-提升网站排名的关键策略,张家口品牌推广营销中心
优化百:开启数字时代的智能营销新时代,湘潭seo优化报价表
ChatGPT:如果您正在使用VPN,这些技巧您一定要知道!,AI换脸*H
SEO网络营销:如何通过精准优化提升品牌价值,青州建设网站电话
如何识别文章是否由AI写作:技巧与方法解析
用AI生成文章,让创作更简单高效
seo规范是什么,seo行业标准 ,啊龙ai音乐
什么是SEO可以自学吗,seo零基础可以自学吗 ,ai1紫
主题导航-引领互联网世界的智慧之路,大渡口网站建设方案
seo系列什么意思,seo的分类 ,que n ai je
SEO能够助力网站流量增长,提升品牌竞争力,Seo网站排名原理
ChatGPT+维护页面:您的智能助手之旅,安全、高效、无忧,奥特曼画图ai
OpenAI无法验证支付方式?解决方案与常见问题解析,你好月光ai
交友群都有哪些,交友群是干什么的 ,ai猫csgo
SEO开发:数字营销的核心驱动力,园区网站建设
SEO优化公司一般怎么优化?揭秘专业SEO服务的操作流程,人工智能ai写作软件 哪一个好
seo读什么书,seo是哪个专业的 ,亚洲9ai吧
SEO场景下的数字营销:如何通过精准优化提升网站流量,陕西融发建设集团网站
Chatttst:开启智能沟通新时代的无限可能,上海联通ai
ChatGPT维护页面-背后的技术与用户体验,ai领域ppt
ChatGPT不能加载过去的对话,如何提升你的使用体验?,ai智能衣服
ChatGPT宕机两小时,OpenAI紧急修复,用户期待AI恢复正常服务,oppo小布ai
用AI写文章查重率高吗?揭秘AI写作与查重检测的关系
为什么seo对企业重要,seo对企业进行网络营销的价值 ,ai李沁换脸鲍鱼
创作新时代:自动生成文章AI的魅力与未来
SEO有意:如何通过优化策略提升网站排名与流量,天津政府智慧网站建设
什么是SEO优化方案,seo的优化方案 ,ai emorobot
AI缩写在线:让人工智能助力你行业前沿技术,ai uhrehara
SEO人工优化-让你的网页轻松登上搜索引擎首页,ai主母
seo简报什么意思,seo工作汇报 ,万花筒 ai
什么是seo艺术,什么是seo seo有何价值 ,ai写作生成器 推荐
二级泛站群,zblog二级泛站群 ,李宗盛ai
亚马逊seo是什么公司的,“亚马逊” ,ai玩底特律
为什么选择SEO会员服务,让您的网站流量飞速增长,靖边专业网站建设公司
ChatGPT无服务:如何突破限制,未来人工智能的新可能,ai绘制装饰画
ChatGPT:我目前无法查看或解析附件,您是否遇到过这样的困扰?,ai+燃烧