我的编程空间,编程开发者的网络收藏夹
学习永远不晚

JavaScript中无法通过div.style.left获取值怎么办

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

JavaScript中无法通过div.style.left获取值怎么办

这篇文章将为大家详细讲解有关JavaScript中无法通过div.style.left获取值怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

一、问题总结:

    样式必须直接写在元素内部才能通过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获取值怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

JavaScript中无法通过div.style.left获取值怎么办

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

无法从通过 YAML 获取的映射中提取键/值对

php小编小新在使用YAML获取映射时,时常会遇到一个问题,即无法从通过YAML获取的映射中提取键/值对。这个问题在实际开发中是非常常见的,它可能会导致无法正确读取配置文件或者无法获取到正确的数据。在本文中,我们将深入探讨这个问题的原因,并
无法从通过 YAML 获取的映射中提取键/值对
2024-02-09

Java 中如何通过反射来获取属性值?(java中怎么通过反射获取属性值)

在Java开发中,反射是一种强大的机制,它允许程序在运行时动态地获取类的信息、创建对象、调用方法等。其中,通过反射获取属性值是反射机制的一个重要应用场景。本文将详细介绍在Java中如何通过反射获取属性值。一、反射的基本概念
Java 中如何通过反射来获取属性值?(java中怎么通过反射获取属性值)
Java2024-12-19

AJPFX中怎么通过索引获取最大值

本篇文章给大家分享的是有关AJPFX中怎么通过索引获取最大值,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。public class Test1
2023-06-02

java中怎么通过反射获取属性值

在Java中,可以通过反射来获取属性的值。下面是一个示例代码:```javaimport java.lang.reflect.Field;public class ExampleClass {private String name;priv
2023-09-07

在 Java 中如何通过变量名获取变量值?(java怎么通过变量名获取变量值)

在Java编程中,有时我们需要根据变量名来获取其对应的值。这在一些特定的编程场景中是非常有用的,比如在动态配置系统、反射机制等情况下。本文将详细介绍在Java中通过变量名获取变量值的方法。一、使用反射机制获取变量值Jav
在 Java 中如何通过变量名获取变量值?(java怎么通过变量名获取变量值)
Java2024-12-18

java中怎么通过反射获取字段的值

通过反射获取字段的值,可以使用Java中的Field类的get()方法。首先,需要获取字段对应的Class对象,然后再通过Class对象获取Field对象。接下来,可以使用Field对象的get()方法来获取字段的值。下面是一个示例代码:`
2023-09-27

如何通过 Java 反射获取字段的值?(java怎么通过反射获取字段的值)

在Java编程中,反射是一种强大的机制,它允许程序在运行时动态地获取类的信息、创建对象、调用方法和访问字段。通过反射,我们可以在不知道类的具体实现细节的情况下,对类进行操作。本文将介绍如何使用Java反射获取字段的值。一、反射的基本概念
如何通过 Java 反射获取字段的值?(java怎么通过反射获取字段的值)
Java2024-12-22

php中怎么通过获取referer防非法访问

php中怎么通过获取referer防非法访问,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。面是我下载页面down.php 的php代码 现在我发现,用迅雷,谷歌浏览器直接打开,
2023-06-20

docker容器中无法获取宿主机hostname怎么办

小编给大家分享一下docker容器中无法获取宿主机hostname怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在nodejs环境中测试通过,其它语言同理,
2023-06-14

Mybatis无法获取带有下划线前缀字段的值怎么办

这篇文章主要介绍“Mybatis无法获取带有下划线前缀字段的值怎么办”,在日常操作中,相信很多人在Mybatis无法获取带有下划线前缀字段的值怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mybatis
2023-06-21

Ajax获取回调函数无法赋值给全局变量怎么办

小编给大家分享一下Ajax获取回调函数无法赋值给全局变量怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!比如我在别的方法想使用getTree执行后的到的值va
2023-06-08

php获取不到网址中的值怎么办

php获取不到网址中的值的解决办法:1、查看url规则;2、将规则修改为“RewriteRule ^/member/editprivilege/([0-9]+) /access.php?_u=mobile/...”即可获取。
2019-06-20

.net程序通过crontab无法启动怎么办

这篇文章主要介绍“.net程序通过crontab无法启动怎么办”,在日常操作中,相信很多人在.net程序通过crontab无法启动怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”.net程序通过cront
2023-06-22

mybatis-plus无法通过logback-spring输出怎么办

小编给大家分享一下mybatis-plus无法通过logback-spring输出怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!问题描述通过官网配置,将mybatis-plus引入spring boot项目中,但是日
2023-06-25

怎么在jQuery中通过prevAll()方法遍历获取元素

本篇文章给大家分享的是有关怎么在jQuery中通过prevAll()方法遍历获取元素,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。jquery是什么jquery是一个简洁而快速
2023-06-14

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录