JavaScript中无法通过div.style.left获取值的解决方法


Posted in Javascript onFebruary 19, 2017

一、问题总结:

    样式必须直接写在元素内部才能通过div.style.left直接获取属性值(也就是必须是内联样式才行),定义在css中的样式不能通过这种方式获取。

   让元素移动到200停止

setTimeout ( function () {  
  var div = document.getElementById("div4");
  //var left = parseInt(div.style.left) + 5;
  var left = div.offsetLeft + 5;
  
  div.style.left = left + "px";
  if (left < 200) {
    setTimeout( arguments.callee, 50);
  }
  
}, 50);

二、关于offsetLeft和left的区别(关于offsetLeft:https://developer.mozilla.org/zh-CN/docs/Web/API/HTMLElement/offsetLeft)

   1.定义了position:relative或absolute属性的元素才有left属性,元素都有offsetLeft属性。

   2.元素内联样式中设置了left,才能通过div.style.left获取;offsetLeft直接通过div.offsetLeft获取。

   3.left可读可写,获取到的是字符串;offsetLeft只读,获取到的是数字。

  相同点:定位方式一样,如果父元素设置了定位元素(position设置为relative或absolute),则相对于定位元素定位,否则就是相对于根元素定位。

三、案例:

    HTMLElement.offsetParent 是一个只读属性,返回一个指向最近的(closest,指包含层级上的最近)包含该元素的定位元素。如果没有定位的元素,则 offsetParent 为最近 的 table 元素对象或根元素(标准模式下为 html;quirks 模式下为 body)。当元素的 style.display 设置为 "none" 时,offsetParent 返回 null。offsetParent 很有用,因为 offsetTop 和 offsetLeft 都是相对于其内边距边界的。

    下面的span的父元素没有设置定位元素,所以该元素的offsetParent为根元素,此时的offsetTop相对于根元素定位。

<div style="width: 300px; border-color:blue;
 border-style:solid; border-width:1;">
 <span>Short span. </span>
 <span id="long">Long span that wraps withing this div.</span>
 </div>
<div id="box" style="position: absolute; border-color: red;
 border-width: 1; border-style: solid; z-index: 10">
</div>
<script>
 var box = document.getElementById("box");
 var long = document.getElementById("long");
 //
 // long.offsetLeft这个值就是span的offsetLeft.
 // span是个行内元素,它没有没absolute定位,但还是默认offserParent就是父元素,而不是根
 //
 box.style.left = long.offsetLeft + document.body.scrollLeft + "px";
 box.style.top = long.offsetTop + document.body.scrollTop + "px";
 box.style.width = long.offsetWidth + "px";
 box.style.height = long.offsetHeight + "px";
</script>

JavaScript中无法通过div.style.left获取值的解决方法

如果给long的父元素添加一个定位属性,结果如下:

JavaScript中无法通过div.style.left获取值的解决方法

 四、总结:

   javascript中通过offsetLeft(offsetTop)方法获取元素偏移值很方便,得到的是数值;改变元素的偏移值使用style.left(top、right、bottom),通过style.left获取的是一个字符串的值,如果要通过style.left来改变元素位置,先要通过parseInt将获取到的当前left值转化为数值。

以上所述是小编给大家介绍的JavaScript中无法通过div.style.left获取值的解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言。

Javascript 相关文章推荐
Javascript 继承实现例子
Aug 12 Javascript
12款经典的白富美型—jquery图片轮播插件—前端开发必备
Jan 08 Javascript
js中apply方法的使用详细解析
Nov 04 Javascript
JavaScript中双叹号(!!)作用示例介绍
Apr 10 Javascript
jQuery如何取id有.的值一般的方法是取不到的
Apr 18 Javascript
为jQuery-easyui的tab组件添加右键菜单功能的简单实例
Oct 10 Javascript
jQuery 获取select选中值及清除选中状态
Dec 13 Javascript
半个小时学json(json传递示例)
Dec 25 Javascript
Node.js+ES6+dropload.js实现移动端下拉加载实例
Jun 01 Javascript
彻底搞懂JavaScript中的apply和call方法(必看)
Sep 18 Javascript
echarts大屏字体自适应的方法步骤
Jul 12 Javascript
ES6 Generator基本使用方法示例
Jun 06 Javascript
JS获取浮动(float)元素的style.left值为空的快速解决办法
Feb 19 #Javascript
Angular 输入框实现自定义验证功能
Feb 19 #Javascript
js实现九宫格的随机颜色跳转
Feb 19 #Javascript
原生JS实现垂直手风琴效果
Feb 19 #Javascript
js鼠标移动时禁止选中文字
Feb 19 #Javascript
canvas雪花效果核心代码分享
Feb 19 #Javascript
Ajax和Comet技术总结
Feb 19 #Javascript
You might like
php md5下16位和32位的实现代码
2008/04/09 PHP
编写Smarty插件在模板中直接加载数据的详细介绍
2013/06/26 PHP
关于PHP中Session文件过多的问题及session文件保存位置
2016/03/17 PHP
PHP Smarty模版简单使用方法
2016/03/30 PHP
深入剖析PHP中printf()函数格式化使用
2016/05/23 PHP
laravel实现分页样式替换示例代码(增加首、尾页)
2017/09/22 PHP
PHP实现求连续子数组最大和问题2种解决方法
2017/12/26 PHP
使用composer 安装 laravel框架的方法图文详解
2019/08/02 PHP
关于Laravel参数验证的一些疑与惑
2019/11/19 PHP
jquery实现图片渐变切换兼容ie6/Chrome/Firefox
2013/08/02 Javascript
javascript 构造函数方式定义对象
2015/01/02 Javascript
JavaScript 学习笔记之变量及其作用域
2015/01/14 Javascript
JavaScript时间转换处理函数
2015/04/14 Javascript
Jquery实现动态切换图片的方法
2015/05/18 Javascript
微信小程序 http请求详细介绍
2016/10/09 Javascript
原生js实现节日时间倒计时功能
2017/01/18 Javascript
NodeJS爬虫实例之糗事百科
2017/12/14 NodeJs
vue-router配合ElementUI实现导航的实例
2018/02/11 Javascript
webpack4.x打包过程详解
2018/07/18 Javascript
node学习笔记之读写文件与开启第一个web服务器操作示例
2019/05/29 Javascript
[39:52]2018DOTA2亚洲邀请赛 4.3 突围赛 EG vs Newbee 第一场
2018/04/04 DOTA
python 利用文件锁单例执行脚本的方法
2019/02/19 Python
Python使用matplotlib 画矩形的三种方式分析
2019/10/31 Python
Python3+SQLAlchemy+Sqlite3实现ORM教程
2021/02/16 Python
css3 transform导致子元素固定定位变成绝对定位的方法
2020/03/06 HTML / CSS
GUESS盖尔斯法国官网:美国时尚品牌
2016/09/23 全球购物
世界上最悠久的自行车制造商:Ribble Cycles
2017/03/18 全球购物
PatPat德国:妈妈的每日优惠
2019/10/02 全球购物
PHP如何设置和取得Cookie值
2015/06/30 面试题
AJAX都有哪些有点和缺点
2012/11/03 面试题
办公室文员工作职责
2014/01/31 职场文书
疾病防治方案
2014/05/31 职场文书
2014个人年度工作总结
2014/12/15 职场文书
python如何获取网络数据
2021/04/11 Python
MySQL中InnoDB存储引擎的锁的基本使用教程
2021/05/26 MySQL
一篇文章看懂MySQL主从复制与读写分离
2021/11/07 MySQL