JavaScript攻克轮播图之style.left与offsetLeft的区别

今天写完作业实在无聊,看着页面上面毫无灵魂的轮播图(不会动)感觉十分差劲,于是翻开了之前写的京东案例,想根据最近学的js基础尝试着完善之前写过的轮播图代码,看懂了个大概,关于函数和逻辑方面略懂了一些,但是到最后还是没有完全理解下来,虽然图片有了灵魂(可以动);但是并不是有趣的灵魂(有很多bug);试问这样的灵魂有何用.郁闷了半天,顺便调戏了半天度娘,结果度娘就是度娘,就跟你娘一样,东西是很多,但都是废话;郁闷之余写下这篇博客,俗话说"打败一个敌人之前,首先要了解它",而摆在我面前敌人有两个style.left与offsetLeft,所以我的这篇博客主要内容是总结一下这两货的特点,为下次的交锋做准备(度娘提供,爱信不信,反正我是信的)
在这里插入图片描述
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只能读取不能配置。

结语:一个人如果不能让自己的页面与众不同起来,那么他和咸鱼有什么分别.

ps:本文纯属原创,抄袭必究.

猜你喜欢

转载自blog.csdn.net/weixin_44387879/article/details/85955248