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 相关文章推荐
jQuery布局插件UI Layout简介及使用方法
Apr 03 Javascript
JS获取select的value和text值的简单实例
Feb 26 Javascript
from表单多个按钮提交用onclick跳转不同action
Apr 24 Javascript
使用JavaScript获取地址栏参数的方法
Dec 19 Javascript
javascript 中的继承实例详解
May 05 Javascript
js学习总结_轮播图之渐隐渐现版(实例讲解)
Jul 17 Javascript
vue.js在标签属性中插入变量参数的方法
Mar 06 Javascript
详解Vue Elementui中的Tag与页面其它元素相互交互的两三事
Sep 25 Javascript
vue-cli3.0 脚手架搭建项目的过程详解
Oct 19 Javascript
vue-cli3 karma单元测试的实现
Jan 18 Javascript
Vue2.4+新增属性.sync、$attrs、$listeners的具体使用
Mar 08 Javascript
js实现简单的点名器随机色实例代码
Sep 20 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类中Static方法效率测试代码
2010/10/17 PHP
php二分查找二种实现示例
2014/03/12 PHP
不使用php api函数实现数组的交换排序示例
2014/04/13 PHP
php查询mysql数据库并将结果保存到数组的方法
2015/03/18 PHP
PHP制作用户注册系统
2015/10/23 PHP
php微信高级接口群发 多客服
2016/06/23 PHP
PHP使用HTML5 FileApi实现Ajax上传文件功能示例
2019/07/01 PHP
jQuery中:submit选择器用法实例
2015/01/03 Javascript
transport.js和jquery冲突问题的解决方法
2015/02/10 Javascript
Angularjs的Controller间通信机制实例分析
2016/11/07 Javascript
实例解析jQuery中如何取消后续执行内容
2016/12/01 Javascript
Spring shiro + bootstrap + jquery.validate 实现登录、注册功能
2017/06/02 jQuery
关于Google发布的JavaScript代码规范你要知道哪些
2018/04/04 Javascript
javascript中call()、apply()的区别
2019/03/21 Javascript
js笔试题-接收get请求参数
2019/06/15 Javascript
vue 使用高德地图vue-amap组件过程解析
2019/09/07 Javascript
js实现列表按字母排序
2020/08/11 Javascript
Python设计模式之观察者模式实例
2014/04/26 Python
Python中基本的日期时间处理的学习教程
2015/10/16 Python
Python使用微信SDK实现的微信支付功能示例
2017/06/30 Python
python Socket之客户端和服务端握手详解
2017/09/18 Python
使用python将请求的requests headers参数格式化方法
2019/01/02 Python
python 同时读取多个文件的例子
2019/07/16 Python
Python3 集合set入门基础
2020/02/10 Python
python 实现全球IP归属地查询工具
2020/12/18 Python
CSS3中31种选择器使用方法教程
2013/12/05 HTML / CSS
HTML5 微格式和相关的属性名称
2010/02/10 HTML / CSS
美国最古老的精致书写工具制造商:A.T. Cross(高仕)
2018/01/30 全球购物
Camper鞋西班牙官方网上商店:西班牙马略卡岛的鞋类品牌
2019/03/14 全球购物
芬兰设计商店美国:Finnish Design Shop US
2019/03/25 全球购物
Yahoo-PHP面试题4
2012/05/05 面试题
成品仓管员岗位职责
2013/12/11 职场文书
毕业证丢失证明范本
2014/09/20 职场文书
房屋出租协议书范本(标准版)
2014/09/24 职场文书
远程教育学习心得体会
2016/01/23 职场文书
《月球之谜》教学反思
2016/02/20 职场文书