方法一:
类似于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’);
}










