首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >document.ready vs document.onLoad

document.ready vs document.onLoad
EN

Stack Overflow用户
提问于 2012-11-17 00:43:49
回答 1查看 10.1K关注 0票数 3

我想知道哪一个是正确的运行js代码,它根据窗口高度计算垂直菜单的高度,并设置它的时间,而不是晚,而不是早。

我正在使用document.ready,但它并没有真正帮助我解决这个问题,它有时不能设置,我必须重新加载页面,然后它才能工作,但不是在第一次加载时。

如何解决这个问题?

下面是我的代码:

代码语言:javascript
运行
复制
$(document).ready(function(){
     var winh = document.body.clientHeight;
     var footer = document.getElementById('footer').offsetHeight;
     document.getElementById('sidebar').style.height = winh - 5/2*footer + 'px';
     document.getElementById('sidebar').style.marginBottom = footer + 'px';

     $(window).resize(function(){
         var winh = document.body.clientHeight;
         var footer = document.getElementById('footer').offsetHeight;
         document.getElementById('sidebar').style.height = winh - 5/2*footer + 'px';
         document.getElementById('sidebar').style.marginBottom = footer + 'px';
     });
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2012-11-17 00:52:37

ready

当您在文档准备就绪时运行代码时,这意味着DOM已加载-但不是图像之类的内容。如果图像会影响高度和宽度,并且图像标签没有设置宽度和高度,那么ready不是您的选择-否则它很可能是。

onload

这包括图像-因此所有内容都将被加载。这意味着它触发的时间稍晚一些。

对两个执行

代码语言:javascript
运行
复制
var calculateSize = function () {
     var winh = document.body.clientHeight;
     var footer = document.getElementById('footer').offsetHeight;
     document.getElementById('sidebar').style.height = winh - 5/2*footer + 'px';
     document.getElementById('sidebar').style.marginBottom = footer + 'px';
}

$(document).ready(function(){
    calculateSize();

     $(window).resize(calculateSize);
});

window.onload = calculateSize ;
票数 5
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/13420811

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档