(交叉浏览)检索可用的水平宽度并将其应用于 div
可以说我有一个水平网站( http://toniweb.us/gm2/ )并且在某个我想知道有多少水平宽度可用,
我制作了这张图片,以便更容易理解
所以我需要获得额外空间的宽度
,我正在尝试这样:
$(window).outerWidth(true)-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))
也尝试过
$(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))
,但在 IE8 中它没有返回相同的值...
然后我需要将它应用到 div,我做了这个函数
function rellenarEspacio(){
if(lte8){
var w = $(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))+$('#nvl2').outerWidth(true);
}else{
var w = $(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true));
}
//alert(w);
$('.extra').css({'display':'block'});
$('.extra').css({'width':w});
return false
}
但没有使用整个空间
知道我错过了什么吗?
lets say i have an horizontal webiste ( http://toniweb.us/gm2/ ) and in a certain point i would like to know how much horizontal width is avaliable,
i made this picture so it's easier to understand
So i would need to get the EXTRA SPACE's width
and i am trying like this:
$(window).outerWidth(true)-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))
also tried
$(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))
but in IE8 it's not returning the same value...
and then i need to apply it to the div, i made this function
function rellenarEspacio(){
if(lte8){
var w = $(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true))+$('#nvl2').outerWidth(true);
}else{
var w = $(window).width()-($('header').outerWidth(true)+$('#nvl1').outerWidth(true)+$('#nvl2').outerWidth(true));
}
//alert(w);
$('.extra').css({'display':'block'});
$('.extra').css({'width':w});
return false
}
but is not using the whole space
any idea what I am missing?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
data:image/s3,"s3://crabby-images/d5906/d59060df4059a6cc364216c4d63ceec29ef7fe66" alt="扫码二维码加入Web技术交流群"
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(1)
解释
你得到一个负值,因为……嗯,因为这是正确的。
如果您有 3 个 div 始终占用 X 空间,而您的视口小于所有 div 宽度的总和,则没有剩余空间。
data:image/s3,"s3://crabby-images/76f71/76f716ed9c7200b8d953ac73b59451842a696379" alt="显示一些空间"
为了最好地描述它,我打印了我的 JSFiddle 示例:
在这里你可以看到有足够的空间,准确地说是 235px。
虽然窗口的宽度大于所有 div 宽度的总和,但仍然有剩余空间。
此时窗口和文档都显示相同的宽度,因此两者都是有效的。
这里已经没有空间了。
在您的情况下,这将变成
530 -(200 + 200 + 200) = -70)
空白区域。看看会发生什么:
窗口宽度实际上小于文档宽度。为什么?
嗯,因为我将窗口大小调整得那么小,这就是原因。
另一方面,文档宽度仍然是所有这些 div 宽度的总和。
这样做的原因是因为您拥有视口的大小,即窗口的大小,而不是包含所有元素的文档的大小。
因此,总而言之:使用
$(document).width()
代替,应该可以解决问题。解决方案
这里是有关其工作原理的示例。
这是我的解决方案。
其他信息
在使用
outerWidth()
函数之前,您应该查看文档不得不说:IE8 之所以返回与其他浏览器不同的值,是因为 IE 很糟糕。 :)
不,但说真的,IE8 可能具有不同的框大小属性,并因此给您带来不同的结果,并且您正在使用
outerWidth()
;如前所述,这不是该功能的正确应用程序。查看此答案。
Explanation
You're getting a negative value because... well because that's correct.
If you've got 3 divs that always take up X amount of space while your viewport is smaller than all the div widths combined, there is no space left.
data:image/s3,"s3://crabby-images/76f71/76f716ed9c7200b8d953ac73b59451842a696379" alt="Showing some space"
To best describe it, I've print screened my JSFiddle example:
Here you can see there is plenty of space, 235px to be exact.
While the window's width is larger than the sum of all the div widths, there is still space left.
Both window and document show the same width at this point, so both are valid.
Here, there is no space left.
In your case, this would become
530 -(200 + 200 + 200) = -70)
empty space.Look what happens:
The window width is actually smaller than the document width. Why?
Well, because I resized the window to be that small, that's why.
The document width on the other hand is still the sum of all those div widths.
The reason for this, is because you have the size of the viewport, meaning, the size of your window, not the size of the document that contain all your elements.
So, to conclude: using this
$(document).width()
instead, should fix the problem.Solution
Here is the example on how it works.
And here's my solution.
Additional information
Before you use the
outerWidth()
function, you should check out what the documentation has to say:The reason why IE8 return a different value than the other browsers, is because IE sucks. :)
No, but seriously, IE8 probably has a different box-sizing property and gives you a different result because of it, and you're using
outerWidth()
; which, as previously mentioned, is not the correct application for that function.Check out this answer.