页面加载完前执行所有的js代码 解决方案

本文介绍了两种确保网页加载过程中JS代码能被正确执行的方法。第一种由Dean Edwards提出,但不支持Safari和Opera浏览器。第二种方案改进了这一点,通过不同浏览器特性实现,包括IE、Mozilla、Safari等。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

在网页加载的同时执行js代码,在加载完前执行所有的js代码:

1、Dean Edwards(js大神)解决方法,暂时不支持Safari和Opera浏览器:

<script type="text/javascript">

function init(){

if(arguments.callww.done)return;   //如果这个功能正在用再次加载时就结束

arguments.callee.done=true ;        //作为函数不加载多次的标志

 //创建页面正在加载的信息;

var text=document.createTextNode(“Page loaded”);

var message=documents.getElementsById("message");

message.appendChild(text);

}

if(document.addEventListener){  //mozilla显示

document.addEventListener("DomContentLoaded",init,false);

}

document.write("<script defer src=ie_onload.js><"+"/script>");   //ie浏览器

window.onload=init;     //其他浏览器

</script>

这种方法存在缺点:(1)对于ie浏览器需要额外的javascript文件,(2)不支持safari和opera浏览器

2、支持safari浏览器的页面加载的方案:

<script type="text/javascript">

function init(){

if(arguments.callww.done)return;   //如果这个功能正在用再次加载时就结束

arguments.callee.done=true ;        //作为函数不加载多次的标志

if(_timer)  clearInterval(_timer);  //关闭计时器

//做其他工作;

}

if(document.addEventListener){  //mozilla显示

document.addEventListener("DomContentLoaded",init,false);

}

//ie浏览器

document.write("<script id=_ie_onload defer src=javascript:viod(0)></script>");

var script=document.getElementById("_ie_onload");

script.onreadystatechange=fuunction(){

if(this.readyState=="complete"){

init();   //调回页面加载处理函数

}}

//针对safari

if(/WebKit/i.test(navigator.userAgent) ) {  //嗅探

var _timer=setInterval(function(){

if(/loaded  | complete/.test(document.readyState) ){

init();     //调回页面加载处理函数

}},10)

}

  window.onload=init;     //其他浏览器

</script>


转载于:https://my.oschina.net/u/2306718/blog/600180

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值