ps 可能篇幅比较长,请大家耐心看看

今天有人在群里问我 动态获取高度怎么获取  我就说jq中的outerHeight、 height 、innerHeight   原生的height clientHeight、scrollHeight、offsetHeight  按道理百度一下 就ok 了  但是他问了一句这些有什么区别? 哎呦 我去 我还真的需要整理一下   好吧 咱们开始整理一下

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; }
</style>
</head>
<body>
<div id="div1"></div>
</body>
</html>

咱们先弄一个div放在这里   然后测试一下这些的区别 然后总结一下

这个是火狐中的盒模型解析出来的结果 请看好

下边咱们开始 直接写js  开始测试

先说一下这个height (因为他奇葩)有两点

1、height:

(1)其实Height高度跟其他的高度有点不一样,在javascript中它是属于对象的style对象属性中的一个成员,它的值是一个字符类型的,而另外 三个高度的值是int类型的,它们是对象的属性.因此这样document.body.height就会提示undenifine,而必须写成 document.body.style.height   (好坑)

(2)只能在div在行内样式设置了height才能获取到(注意是行内 )----------->更坑

那么关于height的代码咱们发一下 (实际项目中应该用不到这么坑的东西了吧)

所以这个height 你在行内写了多少就是多少了(当然没有padding  border之类的计算了)

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; }
</style>
</head>
<body>
<div id="div1" style="height:200px"></div>
<script type="text/javascript">
window.onload=function () {
var oDiv =document.getElementById('div1');
alert( oDiv.style.height)//200
}
</script>
</body>
</html>

2、clientHeight: 是可见区域的宽度  也就是算上padding    不算border 的

window.onload=function  () {
var oDiv =document.getElementById('div1');
alert( oDiv.clientHeight)
}//结果也是200

3、scrollHeight:它其实就是滚动条可滚动的部分还要加上boder的高度还要加上横向滚动条不可用的高度,与clientHeight比起来,多个border的高度跟横向滚动条不可用的高度.

我测试以后 发现火狐和谷歌都是不一样的数值  哎。。看来这个是不好用的  那就不上代码了  忽略它吧  倒是有很多项目中有获取到屏幕的顶部的距离这个效果之类的 等下次再说(感觉已写 就写出来的多了)

4、offsetHeight:均表示是自身的高度,如果有设置boder和padding的话还应该加上boder的值(例子中没有写padding 你可以自己加上是计算在内的)

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; }
</style>
</head>
<body>
<div id="div1" ></div>
<script type="text/javascript">
window.onload=function () {
var oDiv =document.getElementById('div1');
alert( oDiv.offsetHeight)//202 加上border
}
</script>
</body>
</html>

好了原生的写完了 看一下就知道怎么回事了

下边开始说jq方法 看看封装以后是怎么样的

1、outerHeight:api 解释的很详细啊

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; }
</style>
</head>
<body>
<div id="div1" ></div>
<script type="text/javascript"src="http://libs.baidu.com/jquery/2.0.3/jquery.min.js"></script>//百度的cdn
<script type="text/javascript">
$(function () {
alert($("#div1").outerHeight());//202
})
</script>
</body>
</html>

如果不设置为true的话 那么计算外部高度就是本身的200px+边框的2px ------->=202px;

如果你设置为true的话那么结果就是222 就加上了内边距20px

2、height:详细的api啊

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; }
</style>
</head>
<body>
<div id="div1" ></div>
<script type="text/javascript"src="http://libs.baidu.com/jquery/2.0.3/jquery.min.js"></script>
<script type="text/javascript">
$(function () {
alert($("#div1").height());//200px
})
</script>
</body>
</html>

看着和js中的height是一样的啊 (除了原生的那两点坑爹)结果是一样的  而且jq还能直接设置数值 也就说获取之后可以直接设置他的height

3、innerHeight:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>动态获取div的高度问题</title>
<style type="text/css">
*{margin:0; padding: 0; border: none; }
body{padding: 100px;}
#div1{width: 200px; height: 200px; margin:10px; border: 1px solid red; padding: 10px; }
</style>
</head>
<body>
<div id="div1" ></div>
<script type="text/javascript"src="http://libs.baidu.com/jquery/2.0.3/jquery.min.js"></script>
<script type="text/javascript">
$(function () {
alert($("#div1").innerHeight());//220px
})
</script>
</body>
</html>

也就是说 会把当前的height数值加上内边框

总结: 写完了。。。。。。。。

从动态获取div高度的问题展开来看的更多相关文章

  1. JS获取div高度的方法

    有时在写页面时,需要获取一个div的高度.怎么才能获取呢?哈哈,先上结论.有两种方法. offsetHeight .clientHeight getComputedStyle offsetHeight ...

  2. 动态获取div的高度 随着窗口变化而变化

    // 1.jq法 <script> var winHeight = $(window).height(); $("#show").css("height&qu ...

  3. js使用offsetHeight获取div高度为0的问题

    今晚试了好久没弄出来,后来获取子一层的div就能获取到高度了 我的情况是这样的:我在最外面写一个<div id="mainBody">,  里面写bootstrap的d ...

  4. javascript获取div高度

    DOM的: 获得了div的高度值 = document.getElementById("目标id").offsetHeight;

  5. vue 动态获取div宽高有时候为0的情况

    项目背景: 需要使用echarts进行图表展示.由于div宽高是不固定的,因此需要先获取父级的宽高再把值赋予到图表的div中. 需要使用 this.$nextTick(() => {    }) ...

  6. jquery动态修改div高度

    <!DOCTYPE html> <html> <head> <script src="jquery-1.4.2.min.js">&l ...

  7. 获取iframe(angular 动态页面)高度

    问题比较特殊,google了好久才得到启示 开发的angular页面,需要嵌入到客户的web页中,以iframe方式.由于iframe的高度需要指定,而angular动态生成机制导致页面高度会随时变化 ...

  8. jquery动态改变div宽度和高度

    效果体验:http://keleyi.com/keleyi/phtml/jquery/23.htm 完整代码: <!DOCTYPE html PUBLIC "-//W3C//DTD X ...

  9. Js动态获取iframe子页面的高度////////////////////////zzzz

    Js动态获取iframe子页面的高度   Js动态获取iframe子页面的高度总结 问题的缘由 产品有个评论列表引用的是个iframe,高度不固定于是引发这个总结. 方法1:父级页面获取子级页面的高度 ...

随机推荐

  1. 在Android中解决内存溢出 – OutOfMemoryError

    原文链接:http://riggaroo.co.za/fixing-memory-leaks-in-android-outofmemoryerror/ 注:本文在原文基础上在如何判断内存是否泄露方面进 ...

  2. frp -- proxy name [ssh] is already in use

  3. C++之类成员所占内存大小问题总结

    1.空类所占字节数为1,可见代码如下 #include <iostream> using namespace std; class Parent { }; class Child:publ ...

  4. Qt中重绘制窗口方法:

    void CircleWidget::paintEvent(QPaintEvent * event) { QPainter painter(this); int wight = this->wi ...

  5. crossapp的屏幕适配

    1.分辨率是的某个尺寸大小的屏幕里的像素点数ppi 2.crossapp茶用iphone4为基准比例值为1 3.其它分辨率设备的换算dp = px * 320/ 屏幕PPI 4.crossapp里点. ...

  6. 10 种机器学习算法的要点(附 Python)(转载)

    一.前言 谷歌董事长施密特曾说过:虽然谷歌的无人驾驶汽车和机器人受到了许多媒体关注,但是这家公司真正的未来在于机器学习,一种让计算机更聪明.更个性化的技术 也许我们生活在人类历史上最关键的时期:从使用 ...

  7. 走进C++程序世界-----operator new delete 重载

     在C++ 的世界里,new 和delete 是keyword.而在C的世界里相相应的malloc和free是函数,关键C++的new和delete分析,详见前面的章节.这里就不在过多的介绍了.链接. ...

  8. Linux学习之二十-Linux文件系统

    Linux文件系统 文件系统的定义 文件系统是操作系统的必备软件,文件系统是对一个存储设备上的数据(block)和元数据(inode)进行组织的一种机制.文件系统可以帮助用户管理磁盘空间,进行文件的快 ...

  9. 【Unity】脚本选择打勾的勾选框隐藏

    这个问题事实上已经遇到过好几次了.但又没有特别的须要手动勾选,所以也一直都没在意. 今天研究了一下,原来是由于我删除了Start方法...... 所以.仅仅要脚本中没有Start方法,勾选框就会隐藏掉 ...

  10. Linux——环境变量的文件及配置

    环境变量是包含关于系统及当前登录用户的环境信息的字符串,一些软件程序使用此信息确定在何处放置文件(如临时文件). 一.环境变量文件介绍 转自:http://blog.csdn.net/cscmaker ...