`

height、clientHeight、scrollHeight、offsetHeight区别

 
阅读更多

 

 

我们来实现test中的onclick事件

   function justAtest()
    
{
        var test
= document.getElementById( " test " );
        var test2
= document.getElementById( " test2 " )
        var test3
= document.getElementById( " test3 " )
        var test4
= document.getElementById( " test4 " );     
        alert(test4.style.height);
        alert(test3.style.height);    
        alert(test2.style.height)
        alert(test.style.height);      
        alert(document.body.style.height)
     }


height : 其实Height高度跟其他的高度有点不一样,在 javascript中它是属于对象的style对象属性中的一个成员,它的值是一个字符类型的,而另外三个高度的值是int类型的,它们是对象的属性. 因此这样document.body.height就会提示undenifine,而必须写成document.body.style.height
上面的脚本将依次弹出700px,550px,600px,500px,1000px.height是最简单的了,不必去考虑是否有滚动条及边框等.因此也不做多解释了.
然后我们将脚本换下

     function justAtest()
    
{
        var test
= document.getElementById( " test " );
        var test2
= document.getElementById( " test2 " )
        var test3
= document.getElementById( " test3 " )
        var test4
= document.getElementById( " test4 " );     
        alert(test4.clientHeight);
        alert(test3.clientHeight);    
        alert(test2.clientHeight)
        alert(test.clientHeight);      
        alert(document.body.clientHeight)
     }

运行后火狐的结果为:700,550,583,483,1000
           IE的结果为:700 ,550,583,483,1000
IE与火狐下的运行结果是一致的.下面来看下clientHeight的定义.
clientHeight: 可 见区域的宽度,不包括boder的宽度,如果区域内带有滚动条,还应该减去横向滚动条不可用的高度,正常的是17px,其实就是滚动条的可滚动的部分了, 其实clientHeight与height的高度差不多,如果不带滚动条的话他们的值都是一样的,如果带有滚动条的话就会比height值少17px; 火狐与IE下均为一致.
接着我们来看scrollHeight

function justAtest()
    
{
        var test
= document.getElementById( " test " );
        var test2
= document.getElementById( " test2 " )
        var test3
= document.getElementById( " test3 " )
        var test4
= document.getElementById( " test4 " );     
        alert(test4.scrollHeight);
        alert(test3.scrollHeight);    
        alert(test2.scrollHeight)
        alert(test.scrollHeight);      
        alert(document.body.scrollHeight)
     }

运行后火狐的结果为:700,552,700,602,1002
           IE的结果为: 15, 15 , 700,602, 552
scrollHeight: 这个属性就比较麻烦了,因为它们在火狐跟IE下简直差太多了..
在火狐下还很好理解,它其实就是滚动条可滚动的部分还要加上boder的高度还要加上横向滚动条不可用的高度,与clientHeight比起来,多个border的高度跟横向滚动条不可用的高度.

在IE中 scrollHeight确是指这个对象它所包含的对象的高度加上boder的高度和marging,如果它里面没有包含对象或者这个对象的高度值未设置,那么它的值将为15
最后我们来看offsetHeight

     function justAtest()
    
{
        var test
= document.getElementById( " test " );
        var test2
= document.getElementById( " test2 " )
        var test3
= document.getElementById( " test3 " )
        var test4
= document.getElementById( " test4 " );     
        alert(test4.offsetHeight);
        alert(test3.offsetHeight);    
        alert(test2.offsetHeight)
        alert(test.offsetHeight);      
        alert(document.body.offsetHeight)
     }


offsetHeight:
FF:700,552,602,502,1002
IE:700,552,602,502,1002
这个属性好办,因为在测试中IE跟火狐的结果是一样的,均表示是自身的高度,如果有设置boder的话还应该加上boder的值,因为除了test4这个div外,其他的div均有设置border=1px,所以552=550+2,其他的均一样.

综上所述,clientHeight与height的区别是如果有滚动条时应减去滚动条的17px不可用部分,offsetHeight与 Height的区别是增加了boder的高度,ScrollHeihgt与Height的区别是火狐下与offsetHeight一致,IE下如上所述.

 

 

     //iframe自适应高
        function reinitIframe(){   
            var iframe = document.getElementById("frame_main");
            try{
                var bHeight = iframe.contentWindow.document.body.scrollHeight;
                var dHeight = iframe.contentWindow.document.documentElement.scrollHeight;
                var height = Math.max(bHeight, dHeight);
                iframe.height =  height;
            }catch (ex){}
        }   
        window.setInterval("reinitIframe()", 200);

 

转载自:http://www.cnblogs.com/yuteng/articles/1894578.html

分享到:
评论

相关推荐

    分析clientHeight、offsetHeight、scrollHeight

    在网页开发中,理解和使用`clientHeight`、`offsetHeight`和`scrollHeight`这三个属性是至关重要的。它们都是JavaScript中用于获取元素尺寸的方法,但各有其特定的用途和应用场景。 首先,`clientHeight`属性返回一...

    clientHeight

    ### 四种浏览器对_clientHeight、offsetHeight、scrollHeight、clientWidth、offsetWidth 和_scrollWidth 的解析 在前端开发过程中,我们经常会遇到需要获取页面元素尺寸的情况,这其中包括了元素的高度(`...

    js关于不同浏览器的不同之处

    本文将详细介绍`clientHeight`, `offsetHeight`, `scrollHeight`以及与屏幕尺寸相关的`window.screen.availWidth`, `window.screen.availHeight`, `window.screen.width`, `window.screen.height`, `document.body....

    详解HTML元素的height、offsetHeight、clientHeight、scrollTop等梳理

    尺寸相关:offsetHeight、clientHeight、scrollHeight; 偏移相关:offsetTop、clientTop、scrollTop、pageYOffset、scrollY; 获取相对视口位置:Element.getBoundingClientRect(); 获取元素的style对象:...

    JavaScript之scrollTop、scrollHeight、offsetTop、offsetHeight等属性学习笔记

    clientHeight可以用公式 CSS height + CSS padding – 水平滚动条的高度 (如果存在) 来计算。 如图,这样一个div,它的clientHeight为95,计算:50(height)+30(padding-top)+30(padding-bottom)-15(经测量滚动条...

    对offsetLet,offsetTop,scrollLeft,scrollTop几个方法的理解

    ### 对offsetLeft,offsetTop,scrollLeft,scrollTop...在这个例子中,我们创建了一个宽度过长的`<div>`元素,并通过JavaScript输出了`clientHeight`, `offsetHeight`, `scrollHeight`等属性值,以便观察它们之间的区别。

    js中不同的height, top的区别对比

    在JavaScript中,处理元素的尺寸和位置时,经常会遇到几个关键的属性,它们分别是`clientHeight`, `offsetHeight`, `scrollHeight`, `clientTop`, `offsetTop` 和 `scrollTop`。这些属性对于理解和操作页面元素的...

    javascript 获取当前页面可视高度和宽度及浏览器宽度和高度的函数.pdf

    } else if (document.body.scrollHeight > document.body.offsetHeight){ yScroll = document.body.scrollHeight; } else { yScroll = document.body.offsetHeight; } var windowHeight; if (self....

    获取页面元素实际宽高的属性的使用

    本文将详细介绍`clientWidth`、`clientHeight`、`scrollWidth`、`scrollHeight`、`offsetWidth`、`offsetHeight`等属性及其应用场景。 #### `clientWidth` 和 `clientHeight` - **定义**:`clientWidth`用于获取...

    html DOM 节点的各种高度属性

    如果元素没有滚动条,`scrollHeight`通常等于`clientHeight`。 4. `borderTopWidth`和`borderBottomWidth` 这两个属性分别提供了元素顶部和底部边框的宽度。当计算元素总高度时,需要将这两个值加到`clientHeight`...

    doctype后如何获得body.clientHeight的方法

    具体来说,原本归属于 `document.body` 的一些属性(如 `clientHeight`, `clientWidth`, `offsetWidth`, `offsetHeight`, `scrollWidth`, `scrollHeight`, `scrollTop`, 和 `scrollLeft`)会被重新分配给 `document....

    javascript获取设置div的高度和宽度兼容任何浏览器.docx

    - **现代浏览器**:`offsetHeight`, `offsetWidth`, `clientHeight`, `clientWidth`, `scrollHeight`, `scrollWidth` 均支持。 - **Internet Explorer**:除了 `clientHeight` 和 `clientWidth` 外,其他属性也均...

    javascript 获取当前面可视高度和宽度及浏览器宽度和高度的函数.docx

    } else if (document.body.scrollHeight > document.body.offsetHeight) { // 除了IE外的所有浏览器 yScroll = document.body.scrollHeight; } else { // IE6 Strict模式以及其他浏览器 yScroll = document....

    JS中位置与大小的获取方法

    本文将详细解析`scrollHeight`、`clientHeight`以及`offsetHeight`这三个属性的区别,并通过实例演示它们的应用。 1. `scrollHeight`: `scrollHeight`属性表示DOM元素的实际内容高度,它不包括边框(border),但...

    JS,Jquery获取各种屏幕的宽度和高度

    1. **`document.body.clientWidth`** 和 **`document.body.clientHeight`**: - 这两个属性分别用于获取可视区域的宽度和高度,不包括滚动条和边框。 2. **`document.body.offsetWidth`** 和 **`document.body....

    解决vue项目获取dom元素宽高总是不准确问题

    const elementHeight = this.$refs.editor[0].offsetHeight; // 此时,elementHeight 应该是准确的 }); ``` `$nextTick`函数确保在执行回调之前,所有由最近一次Vue实例上的数据变更触发的DOM更新都已完成。这样...

Global site tag (gtag.js) - Google Analytics