返回顶部
首页 > 资讯 > 前端开发 > html >JavaScript中无法通过div.style.left获取值怎么办
  • 238
分享到

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

2024-04-02 19:04:59 238人浏览 薄情痞子
摘要

这篇文章将为大家详细讲解有关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获取值怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: JavaScript中无法通过div.style.left获取值怎么办

本文链接: https://lsjlt.com/news/69047.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • JavaScript中无法通过div.style.left获取值怎么办
    这篇文章将为大家详细讲解有关JavaScript中无法通过div.style.left获取值怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、问题总结: ...
    99+
    2024-04-02
  • 无法从通过 YAML 获取的映射中提取键/值对
    php小编小新在使用YAML获取映射时,时常会遇到一个问题,即无法从通过YAML获取的映射中提取键/值对。这个问题在实际开发中是非常常见的,它可能会导致无法正确读取配置文件或者无法获取...
    99+
    2024-02-09
  • java中怎么通过反射获取属性值
    在Java中,可以通过反射来获取属性的值。下面是一个示例代码:```javaimport java.lang.reflect.Fie...
    99+
    2023-09-07
    java
  • AJPFX中怎么通过索引获取最大值
    本篇文章给大家分享的是有关AJPFX中怎么通过索引获取最大值,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。public class Test1 {    &...
    99+
    2023-06-02
  • java中怎么通过反射获取字段的值
    通过反射获取字段的值,可以使用Java中的Field类的get()方法。首先,需要获取字段对应的Class对象,然后再通过Class...
    99+
    2023-09-27
    java
  • JavaScript中怎么获取复选框的值
    JavaScript中怎么获取复选框的值,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。使用JavaScript获取复选框的值<!DOCT...
    99+
    2024-04-02
  • php中怎么通过获取referer防非法访问
    php中怎么通过获取referer防非法访问,相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。面是我下载页面down.php 的php代码 现在我发现,用迅雷,谷歌浏览器...
    99+
    2023-06-20
  • JS和jQuery怎么通过this获取html标签中的属性值
    这篇文章主要介绍JS和jQuery怎么通过this获取html标签中的属性值,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!具体代码如下所示:<html>  &l...
    99+
    2024-04-02
  • Ajax中怎么通过JS代码自动获取表单元素值
    本篇文章为大家展示了Ajax中怎么通过JS代码自动获取表单元素值,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。function getFormQueryS...
    99+
    2024-04-02
  • docker容器中无法获取宿主机hostname怎么办
    小编给大家分享一下docker容器中无法获取宿主机hostname怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!在nodejs环境中测试通过,其它语言同理,...
    99+
    2023-06-14
  • Ajax获取回调函数无法赋值给全局变量怎么办
    小编给大家分享一下Ajax获取回调函数无法赋值给全局变量怎么办,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!比如我在别的方法想使用getTree执行后的到的值va...
    99+
    2023-06-08
  • Mybatis无法获取带有下划线前缀字段的值怎么办
    这篇文章主要介绍“Mybatis无法获取带有下划线前缀字段的值怎么办”,在日常操作中,相信很多人在Mybatis无法获取带有下划线前缀字段的值怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Mybatis...
    99+
    2023-06-21
  • php exec 获取不到值怎么办
    本文操作环境:Windows7系统,PHP7.4版,Dell G3电脑。php exec 获取不到值怎么办?PHP的exec()函数无返回值排查方法:在安全imagemagic时 需要用到 exec很多服务器上安装失败exec()执行外部命...
    99+
    2016-10-15
    php exec
  • javascript怎么获取用户输入值
    这篇文章主要介绍“javascript怎么获取用户输入值”,在日常操作中,相信很多人在javascript怎么获取用户输入值问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”javascript怎么获取用户输入值...
    99+
    2023-06-20
  • javascript中怎么取值
    这篇文章给大家分享的是有关javascript中怎么取值的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。 javascript取值的方法:1、创建一个新...
    99+
    2024-04-02
  • php获取不到网址中的值怎么办
    本文操作环境:Windows7系统、PHP7.1版、Dell G3电脑。php获取不到网址中的值怎么办?php获取不到url问号之后的参数?url规则已定义:RewriteRule ^/member/editprivilege/([0-9]...
    99+
    2019-06-20
    php
  • .net程序通过crontab无法启动怎么办
    这篇文章主要介绍“.net程序通过crontab无法启动怎么办”,在日常操作中,相信很多人在.net程序通过crontab无法启动怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”.net程序通过cront...
    99+
    2023-06-22
  • mybatis-plus无法通过logback-spring输出怎么办
    小编给大家分享一下mybatis-plus无法通过logback-spring输出怎么办,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!问题描述通过官网配置,将mybatis-plus引入spring boot项目中,但是日...
    99+
    2023-06-25
  • 怎么在python中通过help()方法获取函数信息
    本篇文章为大家展示了怎么在python中通过help()方法获取函数信息,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。python的五大特点是什么python的五大特点:1.简单易学,开发程序时,专...
    99+
    2023-06-14
  • 怎么在jQuery中通过prevAll()方法遍历获取元素
    本篇文章给大家分享的是有关怎么在jQuery中通过prevAll()方法遍历获取元素,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。jquery是什么jquery是一个简洁而快速...
    99+
    2023-06-14
软考高级职称资格查询
推荐阅读
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作