解析页面加载与js函数的执行 onload or ready

 更新时间:2013年12月12日 09:30:57   作者:  
这篇文章主要介绍了页面加载与js函数的执行 onload or ready 需要的朋友可以过来参考下,希望对大家有所帮助

首先,页面加载顺序:
解析HTML结构。
加载外部脚本和样式表文件。
解析并执行脚本代码。
构造HTML DOM模型。
加载图片等外部文件。
页面加载完毕。

也就是:
html → head → title → #text(网页标题) → style → 加载样式 → 解析样式 → link → 加载外部样式表文件 → 解析外部样式表 → script → 加载外部脚本文件 → 解析外部脚本文件 → 执行外部脚本 → body → div → script → 加载脚本 → 解析脚本 → 执行脚本 → img → script → 加载脚本 → 解析脚本 → 执行脚本 → 加载外部图像文件 → 页面初始化完毕。

JS 的初始化装载。

onload
不是在 document 加载完成的时候调用的, 而是在页面所有元素 (包括图片等) 全部加载完成才会调用.  如果页面上有尺寸很大的图片, 下载需要很长时间, 那么脚本就一直不能被初始化, 直到图片装载完成, 严重时用户体验会受到很大影响.但是,window.onload 也并非是一无用处,很多情况下一些B/S软件需要页面全部加载后才提供用户相关功能,这样 window.onload 就可以提供一种“加载中”的功能,又或者是页面内容很少,完全无需 document.ready(); 根据各种情况,应该合理的使用 onload 和 ready。

使用onload加载:

复制代码 代码如下:

window.onload=function(){
            var currentRenderer = 'javascript';           
            FusionCharts.setCurrentRenderer(currentRenderer);
            var chartObj = new FusionCharts({
                swfUrl: "Pie3D.swf",
                width: "290", height: "210",
                id: 'sampleChart',
                dataSource: "/ucenter/seo/new_seo_tool.php?check=xml&val={{pre_num}}",
                dataFormat: FusionChartsDataFormats.XMLURL,         
                renderAt: 'chart1div'
            }).render();
            }

ready
在 W3C 中有个叫 DOMContentLoaded 的事件,它会在 DOM (文档对象模型) 被加载完成的时候触发.

方法一:

复制代码 代码如下:

类似于Jquery的$(function(){...}) $(document).ready(function(){...})
(function () {
var ie = !!(window.attachEvent && !window.opera);
var wk = /webkit\/(\d+)/i.test(navigator.userAgent) && (RegExp.$1 < 525);
var fn = [];
var run = function () { for (var i = 0; i < fn.length; i++) fn[i](); };
var d = document;
d.ready = function (f) {
if (!ie && !wk && d.addEventListener)
return d.addEventListener('DOMContentLoaded', f, false);
if (fn.push(f) > 1) return;
if (ie)
(function () {
try { d.documentElement.doScroll('left'); run(); }
catch (err) { setTimeout(arguments.callee, 0); }
})();
else if (wk)
var t = setInterval(function () {
if (/^(loaded|complete)$/.test(d.readyState))
clearInterval(t), run();
}, 0);
};
})();

调用时:
document.ready(function(){
    alert('ok');
 }

方法二:

复制代码 代码如下:

/如果支持 W3C DOM2, 则使用 W3C 方法
if (document.addEventListener){
    document.addEventListener("DOMContentLoaded", te, false);
}
else if (/MSIE/i.test(navigator.userAgent)){/如果是 IE 浏览器(不支持)
    /创建一个 script 标签, 该标签有 defer 属性, 当 document 加载完毕时才会被载入
    document.write("
    var script = document.getElementByIdx_x("__ie_onload");
    /如果文档确实装载完毕, 调用初始化方法
    script.onreadystatechange = function() {
        if (this.readyState == 'complete') {
        te();
        }
    }
}
else if (/WebKit/i.test(navigator.userAgent)) {/如果是 Safari 浏览器(不支持)
/创建定时器, 每 0.01 秒检验一次, 如果文档装载完毕则调用初始化方法
var _timer = setInterval( function() {
    if (/loaded|complete/.test(document.readyState)) {
        clearInterval(_timer);
        te();
    }
    }, 10);
}
else {/如果以上皆不是, 使用最坏的方法 (本例中, Opera 7 将会跑到这里来)
    window.onload = function(e) {
        te();
    }
}
function te(){
    alert('ok');
}

相关文章

  • JQuery的$命名冲突详细解析

    JQuery的$命名冲突详细解析

    在Jquery中,$是JQuery的别名,所有使用$的地方也都可以使用JQuery来替换,如$('#msg')等同于JQuery('#msg')的写法。然而,当我们引入多个js库后,在另外一个js库中也定义了$符号的话,那么我们在使用$符号时就发生了冲突
    2013-12-12
  • jQuery帮助之CSS尺寸(五)outerHeight、outerWidth

    jQuery帮助之CSS尺寸(五)outerHeight、outerWidth

    在前面我们分别通过innerHeight()和innerWidth()来获得第一个匹配元素内部区域的高度和宽度,我们在应用中往往除了需要内部的尺寸,同样还需要知道外部的高度和宽度.
    2009-11-11
  • jquery通过load获取文件的内容并跳到锚点的方法

    jquery通过load获取文件的内容并跳到锚点的方法

    这篇文章主要介绍了jquery通过load获取文件的内容并跳到锚点的方法,涉及load及animate等方法的使用技巧,需要的朋友可以参考下
    2015-01-01
  • jQuery实现响应鼠标背景变化的动态菜单效果代码

    jQuery实现响应鼠标背景变化的动态菜单效果代码

    这篇文章主要介绍了jQuery实现响应鼠标背景变化的动态菜单效果代码,涉及jquery鼠标mouseover事件操作页面元素属性的相关技巧,具有一定参考借鉴价值,需要的朋友可以参考下
    2015-08-08
  • 将jquery.qqFace.js表情转换成微信的字符码

    将jquery.qqFace.js表情转换成微信的字符码

    这篇文章主要介绍了将jquery.qqFace.js表情转换成微信的字符码的方法,以及jquery.qqface.js的使用方法,需要的朋友可以参考下
    2017-12-12
  • jQuery响应enter键的实现思路

    jQuery响应enter键的实现思路

    当用户在表单里数据完数据后,之间按enter键就可以执行查询或者保存的操作。实现的思路如下
    2014-04-04
  • jQuery实现所有验证通过方可提交的表单验证

    jQuery实现所有验证通过方可提交的表单验证

    这篇文章主要为大家详细介绍了jQuery实现表单验证,所有验证通过方可提交,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-11-11
  • jQuery实现下拉框多选 jquery-multiselect 的实例代码

    jQuery实现下拉框多选 jquery-multiselect 的实例代码

    这篇文章主要介绍了jQuery实现下拉框多选 jquery-multiselect 的实例代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-07-07
  • QUnit jQuery的TDD框架

    QUnit jQuery的TDD框架

    我今天只讨论基于JavaScript的TDD,可能有些公司是用C#做js单元测试的,但我不认为这是个好主意,很多js运行时的东西让js来返回会更直观,且易于维护。
    2010-11-11
  • jQuery标签替换函数replaceWith()的使用例子

    jQuery标签替换函数replaceWith()的使用例子

    这篇文章主要介绍了jQuery标签替换函数replaceWith()的使用例子,使用replaceWith可以替换模板里的标签,还可以实现多语言网站,需要的朋友可以参考下
    2014-08-08

最新评论