jjzjj

clientHeight

全部标签

javascript - 跨多个浏览器一致地获取可用的浏览器窗口大小(clientHeight/clientWidth)

我想要一种在多个浏览器之间获取可用窗口大小的方法,无需使用jQuery/Mootools/任何第三方库依赖项。我对此做了一些研究,但我遇到的一半事情都在谈论NetscapeNavigator...只是想知道是否有人最近有建议。 最佳答案 对于现代浏览器:document.documentElement.clientHeight就是你所需要的。 关于javascript-跨多个浏览器一致地获取可用的浏览器窗口大小(clientHeight/clientWidth),我们在StackOver

javascript - IE8 中的 clientWidth 性能

我有一些遗留的javascript可以卡住表格的tfoot/thead并让主体滚动,它工作正常,除了在IE8中它非常慢。我将问题追溯到读取tfoot/thead中单元格的clientWidth属性...在ie6/7和FireFox1.5-3中读取clientWidth属性大约需要3毫秒...在IE8中需要超过200毫秒当表格中的单元格数量增加时,时间会更长。这是一个已知错误吗?有什么解决方法或解决方案吗? 最佳答案 如果您仍然感兴趣,我已经解决了这个问题。解决方案相当复杂。基本上,您需要将一个简单的HTC附加到该元素并缓存其clie

javascript - 纯 javascript 到 jquery - clientHeight

我有以下脚本(function(win){vardoc=win.document;if(doc.querySelector&&doc.addEventListener){vartoggler=doc.querySelector('.toggle-menu')varmenu=doc.querySelector('.main-navul');menu.style.height='0px';toggler.addEventListener('click',function(e){e.preventDefault();if(menu.style.height=='0px'){menu.styl

javascript - 避免 HTML 文档回流

我有几百个像这样的“行”元素:我需要在它们已经呈现在页面上之后获取它们的clientHeight。我知道“clientHeight”属性强制回流,这会影响我的性能,因为它们太多了。但是-它们已经被渲染并且我知道它们的大小在它们被渲染的时间和我查询它们的高度的时间之间没有变化。有没有办法告诉浏览器在查询高度时不要重排?此外-webkit检查员说:Layouttreesize5901LayoutscopeWholedocument而且div位于绝对定位的祖先中-难道不应该只回流绝对定位的元素吗?编辑:所以提供的答案是正确的。我实际上弄脏了布局,因为我有这个循环:rows.each(func

javascript - 如何在DIV可见前获取clientWidth & clientHeight

我想在style.display='none;'时获取DIV元素(用于在光标位置显示弹出菜单)的尺寸,但是DIV的尺寸总是返回0。我似乎能够获得尺寸的唯一方法是使DIVstyle.display='block;'位于0,0,然后将其移动到所需位置,但是看起来很紧张。我试过使DIV在可见屏幕区域之外可见,但这不起作用。有没有办法在隐藏DIV的同时获取clientWidth和clientHeight值? 最佳答案 如果您的DIV不可见,您将无法获得它的尺寸。但是,有一个解决方法。您的div必须“可见”,但这并不意味着它的不透明度和位置必

javascript - document.documentElement.clientHeight 和 document.body.clientHeight 的区别

document.documentElement.clientHeight和document.body.clientHeight有什么区别?返回值在所有Web浏览器中是否一致,或者每个浏览器的评估方式不同?在我的特殊情况下,documentElement的高度似乎小于body元素,这没有意义。为什么会这样? 最佳答案 document.documentElement属性为您提供了html元素,而document.body属性为您提供了body元素。window.innerHeight属性返回窗口的高度而不是内容的高度。不同的浏览器会

javascript - document.body.clientHeight 不起作用? (JavaScript)

document.body.clientHeight没有返回正确的值(在下面的代码中返回0onload和20onresize)Untitledfunctionheight1(){document.getElementById("viewheight").innerHTML=document.body.clientHeight;}任何评论......请帮助! 最佳答案 尝试使用document.getElementById("viewheight").innerHTML=window.innerHeight;您脚本的行为是完全正确的。

Javascript 以像素为单位获取 100vh

100vhShowmorestuffvarvh=document.getElementById('vh')functionshow(){alert('window.innerHeight='+window.innerHeight+',window.outerHeight='+window.outerHeight+',screen.height='+screen.height+',document.documentElement.clientHeight='+document.documentElement.clientHeight+',vh.clientHeight='+vh.clie

笔记:dom元素各种宽度和高度,getBoundingClientRect,clientWidth,clientHeight,offsetWidth,offsetHeight

HTMLElement.getBoundingClientRectElement.getBoundingClientRect()返回值是一个DOMRect对象,是包含整个元素的最小矩形(包括padding和border-width)。该对象使用left、top、right、bottom、x、y、width和height这几个以像素为单位的只读属性描述整个矩形的位置和大小。除了width和height以外的属性是相对于视图窗口的左上角来计算的。该方法返回的DOMRect对象中的width和height属性是包含了padding和border-width的,而不仅仅是内容部分的宽度和高度。在标准盒

javascript - clientWidth 和 clientHeight 返回 0

这个问题在这里已经有了答案:jquery.readyandheightofelement(1个回答)关闭6年前。为什么clientWidth/Height在IE、Chrome和Safari上返回0?但在Firefox和Opera上运行良好。我使用了这段代码:$(document).ready(function(){varimgs=document.getElementsByTagName('img');varimgLength=imgs.length;for(vari=0;i有什么想法吗?谢谢。我尝试使用window.load和clientwidth,它在Firefox、Chrome和