offsetWidth padding 真实宽度

2020-05-07 13:24:29

为什么我获取到的aDiv.style.width的值为空

style.xxx这个要求写的是行内样式,比如<div style="xx"/>,你可以用offsetWidth


但是offsetWidth的宽度是加上padding和border的,哎,这样我们在世纪应用中一定要去除。


如果要得到真实的width,我们可以先使用getComputedStyle 

如果能获得width证明没有问题,如果获得不了,我们就用offsetWidth减去padding和border,这个我们可以进行封装一下。

具体如何获取 DOM 元素的绝对位置实例详解

参看下面的地址 JS中获取 DOM 元素的绝对位置实例详解


offsetWidth是什么?

答:它可以获取物体宽度的数值

 

那么就只是这样吗!

html部分

<div id="div1"></div>
 
<style>
#div1 { width:200px; height:200px; border:1px solid red; padding:2px; margin:2px; background:green;}
</style>

 

请看上面的html,你知道div1的offsetWidth是多少吗?

是不是200啊

 

哈哈,错了

div1的offsetWidth是206

 

为什么?

答:offsetWidth实际获取的是盒模型(width+border + padding)

200+2+4=206

 

扩展:那么offsetLeft和offsetTop呢

答: offsetLeft = left + marginLeft

     offsetTop = top +marginTop

 

 

示例:让div变窄

现象:onmouseover时,div变窄

 

原理:

oDiv.style.width = oDiv.offsetWidth - 1 + "px";  

 

js部分

 

复制代码

<script>window.onload = function(){    var oDiv = document.getElementById("div1");
    
    oDiv.onmouseover = function(){
        document.title = oDiv.offsetWidth;
        setInterval(function(){
            oDiv.style.width = oDiv.offsetWidth - 1 + "px";            
        },30);
    }
    
}
</script>

复制代码

 

运行上面示例后,你会发现一个奇怪的现象:

div在变宽

 

我们不是要div变窄的吗!它怎么越来越宽了呢?

 

那么这个问题,怎么解决呢?

 

解决方式:

用oDiv.style.width = parseInt(oDiv.style.width) - 1 + "px";

 

但是发现,onmouseover时,div它不动呢?

原因:oDiv.style.width,它只能获取行间的样式

 

所以需要调整成

<div id="div1" style="width:200px;"></div>

 

其实,我们还可以写成一个通用的方法,可以获取任意一个样式

方法:function getStyle(obj,name)

注意:此时样式可以不是行间样式,也能获取

 

知识点:

IE写法:currentStyle

非IE写法: getComputedStyle

 

完整代码,如下

1
2
3
4
5
<div id="div1"></div>
 
<style>
#div1 { width:200px; height:200px; border:1px solid red; padding:2px; margin:2px; background:green;}
</style>

  

复制代码

<script>window.onload = function(){    var oDiv = document.getElementById("div1");
    
    oDiv.onmouseover = function(){
        document.title = oDiv.offsetWidth;
        setInterval(function(){            //oDiv.style.width = oDiv.offsetWidth - 1 + "px";            //oDiv.style.width = parseInt(oDiv.style.width) - 1 + "px";    
            oDiv.style.width = parseInt(getStyle(oDiv,"width"))- 1 + "px";    
        },30);
    }
    
}//获取行间任意样式function getStyle(obj,name){    
    if(obj.currentStyle){    //IE
        return obj.currentStyle[name];
    } else {        return getComputedStyle(obj,false)[name];    //非IE    }
    
    
}</script>

复制代码


  • 2017-04-13 10:57:08

    webstorm 怎么关闭jshint

    You need to configure the inspections in Settings/Editor/Inspections, then in the list on the right, find JavaScript/JavaScript validity issues. That worked for me to remove the Chai warnings. (I am using the WebStorm 11 EAP at the moment.)

  • 2017-04-13 14:11:14

    MySQL中的describe关键字

    今天写代码的时候,有一个类的数据始终不能插入,老是提示在You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'describe, picPath1, picPath2, picPath3, picPath4, picPath5, agentId, belongStore' at line 1。因为用的是SSH进行插入,所以SQL语句不用自己写,检查了每个字段也没写错。

  • 2017-04-15 13:34:08

    Android官方技术文档翻译——清单合并

    一般情况下,有三种类型的清单文件需要合并成一个最终的应用程序清单,这里按照优先级顺序列出: Product flavors 和构建类型所指定的清单文件。 应用程序的主清单文件。 类库的清单文件。

  • 2017-04-15 21:47:44

    Android开发笔记——圆角和边框们

    在做Android界面开发时,我们往往希望它尽可能优美,尽可能显得专业。于是你看了看其他应用,哇,好多边框和圆角啊。你是不是也想给自己的应用加上边框和圆角效果?呃……那怎么做呢?如果你是从web前端跑到Android来的,那么我想你一定想到了不下三种解决方案。如用图片替代,用CSS3定义,用JS画。在Android中,其实也有类似的用法,本文将简单介绍两种Android圆角和边框的实现。

  • 2017-04-15 21:49:06

    Android样式的开发:Style篇

    前面铺垫了那么多,终于要讲到本系列的终篇,整合所有资源,定义成统一的样式。 哪些该定义成统一的样式呢?举几个例子吧:

  • 2017-04-15 23:54:49

    ViewPager+Fragment取消预加载以及禁止滑动

    取消预加载 网上了解了很多取消预加载的方法,里面提到了使用一个viewpager的public方法setOffscreenPageLimit 经过查看源码以及验证发现该方法是管理Viewpager预加载的页数,最低也是默认为一页(例如ViewPager一共有4页,当前手机屏幕显示第一页

  • 2017-04-15 23:56:30

    onInterceptTouchEvent和onTouchEvent调用关系详解

    如果没有onInterceptTouchEvent,只考虑onTouchEvent的话,比较容易分析和理解。假如有三层布局结构,linearLayout1,linearLayout2,textView,从前到后是包含的关系。那么下面分情况说明。