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与Image加载事件(onload)、加载状态(complete)
Feb 14 Javascript
node.js中的http.request.end方法使用说明
Dec 10 Javascript
jQuery中:checked选择器用法实例
Jan 04 Javascript
js判断是否按下了Shift键的方法
Jan 27 Javascript
如何用javascript计算文本框还能输入多少个字符
Jul 29 Javascript
详解JavaScript逻辑And运算符
Dec 04 Javascript
MVC+jQuery.Ajax异步实现增删改查和分页
Dec 22 Javascript
JS简单实现DIV相对于浏览器固定位置不变的方法
Jun 17 Javascript
JS实现页面跳转参数不丢失的方法
Nov 28 Javascript
拖动时防止选中
Feb 03 Javascript
jQuery实现滑动开关效果
Aug 02 jQuery
详解Howler.js Web音频播放终极解决方案
Aug 23 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代码
2007/03/03 PHP
thinkphp3.2中实现phpexcel导出带生成图片示例
2017/02/14 PHP
Laravel下生成验证码的类
2017/11/15 PHP
PHP笛卡尔积实现算法示例
2018/07/30 PHP
用脚本调用样式的几种方法
2006/12/09 Javascript
JavaScript加密解密7种方法总结分析
2007/10/07 Javascript
Javascript优化技巧(文件瘦身篇)
2008/01/28 Javascript
jQuery动态地获取系统时间实现代码
2013/05/24 Javascript
node.js正则表达式获取网页中所有链接的代码实例
2014/06/03 Javascript
js判断空对象的实例(超简单)
2016/07/26 Javascript
jQuery中show与hide方法用法示例
2016/09/16 Javascript
浅谈bootstrap使用中的一些问题以及解决过程
2016/10/18 Javascript
javascript判断firebug是否开启的方法
2016/11/23 Javascript
微信小程序开发的四十个技术窍门总结(推荐)
2017/01/23 Javascript
js实现横向拖拽导航条功能
2017/02/17 Javascript
JavaScript 获取元素在父节点中的下标(推荐)
2017/06/28 Javascript
jQuery实现返回顶部按钮和scroll滚动功能[带动画效果]
2017/07/05 jQuery
在ES5与ES6环境下处理函数默认参数的实现方法
2018/05/13 Javascript
Fundebug支持监控微信小程序HTTP请求错误的方法
2019/02/21 Javascript
layUI实现三级导航菜单效果
2019/07/26 Javascript
Nodejs技巧之Exceljs表格操作用法示例
2019/11/06 NodeJs
微信小程序跨页面传递data数据方法解析
2019/12/13 Javascript
vscode 调试 node.js的方法步骤
2020/09/15 Javascript
python 中的int()函数怎么用
2017/10/17 Python
对python中的logger模块全面讲解
2018/04/28 Python
Python中is和==的区别详解
2018/11/15 Python
Python eval的常见错误封装及利用原理详解
2019/03/26 Python
对Python3之方法的覆盖与super函数详解
2019/06/26 Python
Python 3 使用Pillow生成漂亮的分形树图片
2019/12/24 Python
pycharm设置python文件模板信息过程图解
2020/03/10 Python
sqlalchemy实现时间列自动更新教程
2020/09/02 Python
css3实现平移效果(transfrom:translate)的示例
2020/11/13 HTML / CSS
加拿大领先的时尚和体育零售商:Sporting Life
2019/12/15 全球购物
中科创达面试题
2016/12/28 面试题
房产买卖委托公证书
2014/04/04 职场文书
节约用电标语
2014/06/17 职场文书