JS中height、clientHeight、scrollHeight、offsetHeight区别

JS中height、clientHeight、scrollHeight、offsetHeight区别我们来实现test中的onclick事件  functionjustAtest()    {       vartest= document.getElementById(“test”);       vartest2=document.getElementById(“test2”)       vartest3=document.getElementB

大家好,又见面了,我是你们的朋友全栈君。

 JS中height、clientHeight、scrollHeight、offsetHeight区别

 

我们来实现test中的onclick事件

JS中height、clientHeight、scrollHeight、offsetHeight区别
   function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.style.height); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.style.height);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.style.height)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.style.height);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.style.height) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }


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

JS中height、clientHeight、scrollHeight、offsetHeight区别
     function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.clientHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.clientHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.clientHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.clientHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.clientHeight) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }

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

JS中height、clientHeight、scrollHeight、offsetHeight区别
 function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.scrollHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.scrollHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.scrollHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.scrollHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.scrollHeight) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }

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

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

JS中height、clientHeight、scrollHeight、offsetHeight区别
     function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.offsetHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.offsetHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.offsetHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.offsetHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.offsetHeight) 
JS中height、clientHeight、scrollHeight、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下如上所述.

相信你了解了这个,对width,clientWidth,scrollWidth,offsetWidth已经不陌生了吧,只不过一个是长一个是宽的问题了.

 

 

我们来实现test中的onclick事件

JS中height、clientHeight、scrollHeight、offsetHeight区别
   function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.style.height); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.style.height);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.style.height)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.style.height);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.style.height) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }


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

JS中height、clientHeight、scrollHeight、offsetHeight区别
     function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.clientHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.clientHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.clientHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.clientHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.clientHeight) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }

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

JS中height、clientHeight、scrollHeight、offsetHeight区别
 function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.scrollHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.scrollHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.scrollHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.scrollHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.scrollHeight) 
JS中height、clientHeight、scrollHeight、offsetHeight区别     }

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

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

JS中height、clientHeight、scrollHeight、offsetHeight区别
     function justAtest()
JS中height、clientHeight、scrollHeight、offsetHeight区别    

{

JS中height、clientHeight、scrollHeight、offsetHeight区别        var test
= document.getElementById(test);
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test2
=document.getElementById(test2)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test3
=document.getElementById(test3)
JS中height、clientHeight、scrollHeight、offsetHeight区别        var test4
=document.getElementById(test4);     
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test4.offsetHeight); 
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test3.offsetHeight);    
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test2.offsetHeight)
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(test.offsetHeight);      
JS中height、clientHeight、scrollHeight、offsetHeight区别        alert(document.body.offsetHeight) 
JS中height、clientHeight、scrollHeight、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下如上所述.

相信你了解了这个,对width,clientWidth,scrollWidth,offsetWidth已经不陌生了吧,只不过一个是长一个是宽的问题了.

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163758.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • asp:ScriptManager

    asp:ScriptManager概述ScriptManager控件管理用于MicrosoftASP.NETAJAX页面的客户端脚本。默认情况下,ScriptManager控件将MicrosoftAJAX库的脚本与页面注册到一起,这使脚本可以使用类型系统扩展并支持局部页面输出和Web服务调用。在页面中,必须使用ScriptManager控件来使下列MicrosoftASP.NETAJAX的特性可用…

    2022年7月13日
    22
  • Java算法大全_java贪心算法几个经典例子

    Java算法大全_java贪心算法几个经典例子Java经典问题算法大全/*【程序1】题目:古典问题:有一对兔子,从出生后第3个月起每个月都生一对兔子,小兔子长到第三个月后每个月又生一对兔子,假如兔子都不死,问每个月的兔子总数为多少?1.程序分析:兔子的规律为数列1,1,2,3,5,8,13,21….*/packagecn.com.flywater.FiftyAlgorthm;publicclassFirstR

    2022年10月17日
    2
  • 关于前端iframe嵌套页面的跳转问题

    关于前端iframe嵌套页面的跳转问题因工作中遇到的项目,有iframe页面嵌套,遇到了页面跳转的问题,所以记录解决问题的过程关于前端iframe嵌套页面的跳转问题问题:在A页面使用iframe嵌套了B页面,B页面中做了权限校验,即登录成功后才可以访问B中的某个页面,如果没有登录,则跳转A登录页面.过程:开始在B中尝试使用页面跳转location.href=”A登录的页面地址”,一直访问失败,且浏览器地址栏的url也没有变化,查询相关资料得到解决方法.解决方案:使用:windows.parent.location.href=”.

    2022年6月16日
    250
  • Unity3D 虚拟现实开发(一)[通俗易懂]

    Unity3D 虚拟现实开发(一)[通俗易懂]大家好,这是我第一篇文章,之前做房地产虚拟现实工作,是时候总结一下制作经验了,现在想将简单的制作流程及设计到的问题整理出来,供大家参考。Unity3D软件安装。以2018.2.14例访问地址:https://unity3d.com/cn/get-unity/download/archive?_ga=2.194947693.1768064749.1541907838-1070007498…

    2022年9月13日
    2
  • java面试两年工作经验的_无经验应届生面试自我介绍

    java面试两年工作经验的_无经验应届生面试自我介绍动机:最近换了个公司,从三月底开始面,面到四月底,面了有快二十家公司。我是一个喜欢总结经验的人,每经过一场面试,我在回来的路上都会仔细回想今天哪些问题可以答的更好,或者哪些问题是自己之前没遇到过的,或者是哪个知识点今天又问了等等。四月中旬的时候,我就在构思要写一篇面经,主要是想着可能对那些跟我相同处境的人有点帮助,再者就是稍微记录下这为期一个月的面试过程。本文地址:http://blog….

    2022年8月10日
    7
  • PyCharm激活码永久有效PyCharm2017.3.7激活码教程-持续更新,一步到位

    PyCharm激活码永久有效PyCharm2017.3.7激活码教程-持续更新,一步到位PyCharm激活码永久有效2017.3.7激活码教程-Windows版永久激活-持续更新,Idea激活码2017.3.7成功激活

    2022年6月19日
    22

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号