一、问题总结:

样式必须直接写在元素内部才能通过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>
如果给long的父元素添加一个定位属性,结果如下:
四、总结:
javascript中通过offsetLeft(offsetTop)方法获取元素偏移值很方便,得到的是数值;改变元素的偏移值使用style.left(top、right、bottom),通过style.left获取的是一个字符串的值,如果要通过style.left来改变元素位置,先要通过parseInt将获取到的当前left值转化为数值。
以上所述是小编给大家介绍的JavaScript中无法通过div.style.left获取值的解决方法,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言。
# div.style.left
# java 线程同步详细介绍及实例代码
# java中@ModelAttribute注解的作用
# 【Java】BigDecimal实现加减乘除运算代码
# JavaScript实现的鼠标响应颜色渐变效果完整实例
# Java 图片与byte数组互相转换实例
# Java使用SFTP上传文件到服务器的简单使用
# 详解租约机制以及在hbase中的应用
# 的是
# 相对于
# 设置为
# 都是
# 是一个
# 是个
# 都有
# 模式下
# 给大家
# 才有
# 如果没有
# 才行
# 转化为
# 写在
# 解决方法
# 很方便
# 所述
# 小编
# 给我留言
# 很有用
相关文章:
如何用手机制作网站和网页,手机移动端的网站能制作成中英双语的吗?
如何用好域名打造高点击率的自主建站?
Thinkphp 中 distinct 的用法解析
,网站推广常用方法?
西安专业网站制作公司有哪些,陕西省建行官方网站?
购物网站制作公司有哪些,哪个购物网站比较好?
香港服务器租用每月最低只需15元?
制作网站的网址是什么,请问后缀为.com和.com.cn还有.cn的这三种网站是分别是什么类型的网站?
外贸公司网站制作,外贸网站建设一般有哪些步骤?
建站主机是什么?如何选择适合的建站主机?
无锡营销型网站制作公司,无锡网选车牌流程?
建站之星图片链接生成指南:自助建站与智能设计教程
实例解析Array和String方法
公司网站制作需要多少钱,找人做公司网站需要多少钱?
大连 网站制作,大连天途有线官网?
东莞专业网站制作公司有哪些,东莞招聘网站哪个好?
存储型VPS适合搭建中小型网站吗?
山东云建站价格为何差异显著?
北京企业网站设计制作公司,北京铁路集团官方网站?
详解一款开源免费的.NET文档操作组件DocX(.NET组件介绍之一)
外贸公司网站制作哪家好,maersk船公司官网?
公司网站设计制作厂家,怎么创建自己的一个网站?
如何续费美橙建站之星域名及服务?
网站制作的软件有哪些,制作微信公众号除了秀米还有哪些比较好用的平台?
邀请函制作网站有哪些,有没有做年会邀请函的网站啊?在线制作,模板很多的那种?
想学网站制作怎么学,建立一个网站要花费多少?
香港服务器网站生成指南:免费资源整合与高速稳定配置方案
如何将凡科建站内容保存为本地文件?
详解免费开源的.NET多类型文件解压缩组件SharpZipLib(.NET组件介绍之七)
活动邀请函制作网站有哪些,活动邀请函文案?
建站之星多图banner生成与模板自定义指南
如何在VPS电脑上快速搭建网站?
建站之星下载版如何获取与安装?
个人摄影网站制作流程,摄影爱好者都去什么网站?
如何在腾讯云免费申请建站?
建站之星后台密码遗忘如何找回?
如何通过虚拟主机空间快速建站?
开源网站制作软件,开源网站什么意思?
如何在Golang中使用replace替换模块_指定本地或远程路径
javascript中的try catch异常捕获机制用法分析
如何在IIS中新建站点并解决端口绑定冲突?
定制建站流程解析:需求评估与SEO优化功能开发指南
如何在云主机快速搭建网站站点?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
公司网站制作价格怎么算,公司办个官网需要多少钱?
建站之星手机一键生成:多端自适应+小程序开发快速建站指南
中山网站推广排名,中山信息港登录入口?
c# Task.Yield 的作用是什么 它和Task.Delay(1)有区别吗
教学网站制作软件,学习*后期制作的网站有哪些?
建站与域名管理如何高效结合?
*请认真填写需求信息,我们会在24小时内与您取得联系。