JavaScript中style.left与offsetLeft的使用及区别详解


Posted in Javascript onJune 08, 2016

如果父div的position定义为relative,子div的position定义为absolute,那么子div的style.left的值是相对于父div的值,
这同offsetLeft是相同的,区别在于:

1. style.left 返回的是字符串,如28px,offsetLeft返回的是数值28,如果需要对取得的值进行计算,还用offsetLeft比较方便。

2. style.left是读写的,offsetLeft是只读的,所以要改变div的位置,只能修改style.left。

3. style.left的值需要事先定义,否则取到的值为空。而且必须要定义在html里,我做过试验,如果定义在css里,style.left的值仍然 为空,这就是我刚开始碰到的问题,总是取不到style.left的值。

offsetLeft则仍然能够取到,无需事先定义div的位置。

// 这个函数是对 一个无穷分类的 下拉框的操作,页面开始只有一个下拉框,当选中下拉框一个值后,
动态生成一个select, select的项是子分类,同时要使子分类的select框后移 20px;

function itemtree_cats_change ( selectObj )

JavaScript中style.left与offsetLeft的区别说明如下所示:

今天在制作焦点轮播图的时候,遇到一个问题,在使用style.left获取图片的位置时,怎么也获取不到。换用offsetLeft就能够成功获取到了。虽然实现了我想要的效果,但是还是不甘心啊,没有找到原因,心里就是怪怪的,于是我翻开JavaScript高级程序设计,将style.left和offsetLeft有关的知识点都看了一下,做了如下比较。

(一)、对于style.left类属性,JavaScript高级程序是这样描述的:

任何支持style特性的HTML元素在JavaScript中都有一个对应的style属性。这个style对象是CSSStyleDeclaration的实例,包含着通过HTML的style特性指定的所有样式信息,但不包含与外部样式表或嵌入样式表经层叠而来的样式(关键就在这句话!也就是说只有设置为行内样式的style属性才能被获取)。在style特性中指定的任何CSS属性都将表现为这个style对象的相应属性。

(二)、对于offsetLeft累属性:

offsetLeft:元素的左外边框至包含元素的左内边框之间的像素距离。

offsetTop:元素的上外边框至包含元素的上内边框之间的像素距离。

通过看书和今天遇到的问题,对style.left和offsetLeft做如下总结

相同点

1、style.left与offsetLeft都是相对于其父元素的值。

不同点

1、style.left返回的是字符串,带有px;offsetLeft返回的是数值。

2、style.left时可以读取的也是可以配置的;offsetLeft只能读取不能配置。

Javascript 相关文章推荐
Javascript实现的分页函数
Dec 22 Javascript
jquery利用event.which方法获取键盘输入值的代码
Oct 09 Javascript
JavaScript针对网页节点的增删改查用法实例
Feb 02 Javascript
在javascript中随机数 math random如何生成指定范围数值的随机数
Oct 21 Javascript
jQuery Ajax Post 回调函数不执行问题的解决方法
Aug 15 Javascript
概述一个页面从输入URL到页面加载完的过程
Dec 16 Javascript
移动端刮刮乐的实现方式(js+HTML5)
Mar 23 Javascript
Vue关于数据绑定出错解决办法
May 15 Javascript
原生JS写Ajax的请求函数功能
Dec 22 Javascript
浅析java线程中断的办法
Jul 29 Javascript
vue动态改变背景图片demo分享
Sep 13 Javascript
vue3 watch和watchEffect的使用以及有哪些区别
Jan 26 Vue.js
Js+Ajax,Get和Post在使用上的区别小结
Jun 08 #Javascript
jQuery.Uploadify插件实现带进度条的批量上传功能
Jun 08 #Javascript
JS与Ajax Get和Post在使用上的区别实例详解
Jun 08 #Javascript
浅谈JS原生Ajax,GET和POST
Jun 08 #Javascript
原生 JS Ajax,GET和POST 请求实例代码
Jun 08 #Javascript
全面解析jQuery $(document).ready()和JavaScript onload事件
Jun 08 #Javascript
jQuery提示插件qTip2用法分析(支持ajax及多种样式)
Jun 08 #Javascript
You might like
计算php页面运行时间的函数介绍
2013/07/01 PHP
PHP的HTTP客户端Guzzle简单使用方法分析
2019/10/30 PHP
javascript XML数据显示为HTML一例
2008/12/23 Javascript
JS在IE和FireFox之间常用函数的区别小结
2010/03/12 Javascript
jquery获取div宽度的实现思路与代码
2013/01/13 Javascript
javascript通过navigator.userAgent识别各种浏览器
2013/10/25 Javascript
AngularJS基础学习笔记之表达式
2015/05/10 Javascript
js实现点击链接后延迟3秒再跳转的方法
2015/06/05 Javascript
深入理解jQuery之防止冒泡事件
2016/05/24 Javascript
javascript 动态脚本添加的简单方法
2016/10/11 Javascript
JS字符串长度判断,超出进行自动截取的实例(支持中文)
2017/03/06 Javascript
layui点击导航栏刷新tab页的示例代码
2018/08/14 Javascript
如何在vue里面优雅的解决跨域(路由冲突问题)
2019/01/20 Javascript
小程序实现tab标签页
2020/11/16 Javascript
[51:07]VGJ.S vs Pain 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
[01:08:44]NB vs VP 2018国际邀请赛小组赛BO2 第一场 8.18
2018/08/19 DOTA
Python转码问题的解决方法
2008/10/07 Python
python3图片转换二进制存入mysql
2013/12/06 Python
python进阶教程之文本文件的读取和写入
2014/08/29 Python
Python中实现的RC4算法
2015/02/14 Python
Python selenium如何设置等待时间
2016/09/15 Python
Python结合ImageMagick实现多张图片合并为一个pdf文件的方法
2018/04/24 Python
在Pycharm中对代码进行注释和缩进的方法详解
2019/01/20 Python
详解Python数据可视化编程 - 词云生成并保存(jieba+WordCloud)
2019/03/26 Python
python 使用cycle构造无限循环迭代器
2020/12/02 Python
Pytorch1.5.1版本安装的方法步骤
2020/12/31 Python
html5实现完美兼容各大浏览器的播放器
2014/12/26 HTML / CSS
化学学院毕业生自荐信范文
2013/12/17 职场文书
生物科学系大学生的自我评价
2013/12/20 职场文书
面临毕业的毕业生自荐书范文
2014/02/05 职场文书
高中生的自我评价
2014/03/04 职场文书
完美的中文自荐信
2014/05/24 职场文书
园林专业毕业生自荐信
2014/07/04 职场文书
1000字打架检讨书
2014/11/03 职场文书
2015年全民创业工作总结
2015/07/23 职场文书
《为人民服务》教学反思
2016/02/20 职场文书