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 相关文章推荐
CSS(js)限制页面显示的文本字符长度
Dec 27 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
Jan 20 Javascript
基于jQuery实现表单提交验证
Nov 24 Javascript
Bootstrap框架动态生成Web页面文章内目录的方法
May 12 Javascript
AngularJs bootstrap搭载前台框架——js控制部分
Sep 01 Javascript
bootstrap读书笔记之CSS组件(上)
Oct 17 Javascript
使用JS实现图片轮播的实例(前后首尾相接)
Sep 21 Javascript
解决vue的变量在settimeout内部效果失效的问题
Aug 30 Javascript
图文详解vue框架安装步骤
Feb 12 Javascript
弱类型语言javascript开发中的一些坑实例小结【变量、函数、数组、对象、作用域等】
Aug 07 Javascript
vue 解决无法对未定义的值,空值或基元值设置反应属性报错问题
Jul 31 Javascript
原生js实现表格翻页和跳转
Sep 29 Javascript
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
Oracle Faq(Oracle的版本)
2006/10/09 PHP
提交表单后 PHP获取提交内容的实现方法
2016/05/25 PHP
PHP设计模式之模板方法模式定义与用法详解
2018/04/02 PHP
ExtJS GridPanel 根据条件改变字体颜色
2010/03/08 Javascript
基于Asp.net与Javascript控制的日期控件
2010/05/22 Javascript
jQuery老黄历完整实现方法
2015/01/16 Javascript
jQuery实现当前页面标签高亮显示的方法
2015/03/10 Javascript
JavaScript通过字符串调用函数的实现方法
2015/03/18 Javascript
js+HTML5实现视频截图的方法
2015/06/16 Javascript
深入学习JavaScript对象
2015/10/13 Javascript
使用jQuery制作基础的Web图片轮播效果
2016/04/22 Javascript
jQuery ztree实现动态树形多选菜单
2016/08/12 Javascript
Linux CentOS系统下安装node.js与express的方法
2017/04/01 Javascript
Bootstrap组件之下拉菜单,多级菜单及按钮布局方法实例
2017/05/25 Javascript
详解基于 Nuxt 的 Vue.js 服务端渲染实践
2017/10/24 Javascript
使用 Node.js 开发资讯爬虫流程
2018/01/07 Javascript
JS实现多物体运动的方法详解
2018/01/23 Javascript
解决vue项目报错webpackJsonp is not defined问题
2018/03/14 Javascript
JS高阶函数原理与用法实例分析
2019/01/15 Javascript
微信小程序实现banner图轮播效果
2020/06/28 Javascript
vue指令做滚动加载和监听等
2019/05/26 Javascript
浅析JS中NEW的实现原理及重写
2020/02/20 Javascript
React冒泡和阻止冒泡的应用详解
2020/08/18 Javascript
Python httplib模块使用实例
2015/04/11 Python
win10 64bit下python NLTK安装教程
2018/09/19 Python
python列表,字典,元组简单用法示例
2019/07/11 Python
dpn网络的pytorch实现方式
2020/01/14 Python
Django分组聚合查询实例分享
2020/04/29 Python
玛蒂尔达简服装:Matilda Jane Clothing
2019/02/13 全球购物
医校毕业生自我鉴定
2014/01/25 职场文书
会议活动邀请函
2014/01/27 职场文书
2014年度思想工作总结
2014/11/27 职场文书
利用Nginx代理如何解决前端跨域问题详析
2021/04/02 Servers
selenium.webdriver中add_argument方法常用参数表
2021/04/08 Python
Python一行代码实现自动发邮件功能
2021/05/30 Python
MySQL实现用逗号进行拼接、以逗号进行分割
2022/12/24 MySQL