”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 如何准确检索 DOM 元素的 Display 属性以及为什么 .style 属性可能返回空字符串

如何准确检索 DOM 元素的 Display 属性以及为什么 .style 属性可能返回空字符串

发布于2024-11-04
浏览:228

How to Accurately Retrieve the Display Property of a DOM Element and Why the .style Property May Return Empty Strings

检索 DOM 元素的显示属性:揭示真实值

提供的 HTML 代码引入了具有不同显示的段落和锚点风格。但是,通过 style 属性检索这些样式似乎会导致意外的空字符串。为什么会出现这种情况,如何准确检索显示属性?

空字符串之谜

最初的困惑是因为 .style.*属性直接映射到样式属性,而不是应用的样式。这意味着您本质上是在检查内联样式声明,这可能并不总是反映计算的样式。

解决方案: getCompulatedStyle

获取实际应用的样式,包括继承的属性,都需要使用getComputedStyle方法。此方法采用 DOM 元素作为参数,并返回包含计算样式值的 CSSStyleDeclaration 对象。

可以修改提供的代码以使用 getCompulatedStyle,如下所示:

var a = (document.getElementById('a'));
alert(getComputedStyle(a).display);
var p = (document.getElementById('p'));
alert(getComputedStyle(p).display);
p.style.display = 'none';
alert(getComputedStyle(p).display);

现在,第一个警报将为锚点标记显示“none”,第二个警报将为段落元素显示“block”,第三个警报将显示有意显示设置后的“无”。这准确地反映了元素的计算显示样式。

替代方法:类切换

您可以考虑使用类名来切换,而不是依赖于显示属性元素的可见性。通过将表示与逻辑分离,您可以简化代码并使其不易出现与样式相关的问题。

版本声明 本文转载于:1729379537如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 我的 Amazon SDE 面试经历 – 5 月 4 日
    我的 Amazon SDE 面试经历 – 5 月 4 日
    我的 Amazon SDE 面试经历 – 2024 年 5 月 2024 年 5 月,我有机会面试亚马逊的软件开发工程师 (SDE) 职位。这一切都始于一位招聘人员通过 LinkedIn 联系我。我很惊喜,因为它总是令人兴奋。 一切是如何开始的 招聘人员专业且清晰,...
    编程 发布于2024-11-08
  • 为什么 $_POST 中的 Axios POST 数据不可访问?
    为什么 $_POST 中的 Axios POST 数据不可访问?
    Axios Post 参数未由 $_POST 读取您正在使用 Axios 将数据发布到 PHP 端点,并希望在 $ 中访问它_POST 或 $_REQUEST。但是,您目前无法检测到它。最初,您使用了默认的 axios.post 方法,但由于怀疑标头问题而切换到提供的代码片段。尽管发生了这种变化,数...
    编程 发布于2024-11-08
  • ## JPQL 中的构造函数表达式:使用还是不使用?
    ## JPQL 中的构造函数表达式:使用还是不使用?
    JPQL 中的构造函数表达式:有益还是有问题的实践?JPQL 提供了使用构造函数表达式在 select 语句中创建新对象的能力。虽然此功能提供了某些优势,但它引发了关于其在软件开发实践中是否适用的问题。构造函数表达式的优点构造函数表达式允许开发人员从实体中提取特定数据并进行组装,从而简化了数据检索将...
    编程 发布于2024-11-08
  • 原型
    原型
    创意设计模式之一。 用于创建给定对象的重复/浅副本。 当直接创建对象成本高昂时,此模式很有用,例如:如果在查询大型数据库后创建对象,则一次又一次地创建该对象在性能方面并不经济。 因此,一旦创建了对象,我们就缓存该对象,并且在将来需要相同的对象时,我们从缓存中获取它,而不是从数据库中再次创建它,并在需...
    编程 发布于2024-11-08
  • Python 变量:命名规则和类型推断解释
    Python 变量:命名规则和类型推断解释
    Python 是一种广泛使用的编程语言,以其简单性和可读性而闻名。了解变量的工作原理是编写高效 Python 代码的基础。在本文中,我们将介绍Python变量命名规则和类型推断,确保您可以编写干净、无错误的代码。 Python变量命名规则 在Python中命名变量时,必须遵循一定的...
    编程 发布于2024-11-08
  • 如何同时高效地将多个列添加到 Pandas DataFrame 中?
    如何同时高效地将多个列添加到 Pandas DataFrame 中?
    同时向 Pandas DataFrame 添加多个列在 Pandas 数据操作中,有效地向 DataFrame 添加多个新列可能是一项需要优雅解决方案的任务。虽然使用带有等号的列列表语法的直观方法可能看起来很简单,但它可能会导致意外的结果。挑战如提供的示例中所示,以下语法无法按预期创建新列:df[[...
    编程 发布于2024-11-08
  • 从开发人员到高级架构师:技术专长和奉献精神的成功故事
    从开发人员到高级架构师:技术专长和奉献精神的成功故事
    一个开发人员晋升为高级架构师的真实故事 一位熟练的Java EE开发人员,只有4年的经验,加入了一家跨国IT公司,并晋升为高级架构师。凭借多样化的技能和 Oracle 认证的 Java EE 企业架构师,该开发人员已经证明了他在架构领域的勇气。 加入公司后,开发人员被分配到一个项目,该公司在为汽车制...
    编程 发布于2024-11-08
  • 如何在 PHP 8.1 中有条件地将元素添加到关联数组?
    如何在 PHP 8.1 中有条件地将元素添加到关联数组?
    条件数组元素添加在 PHP 中,有条件地将元素添加到关联数组的任务可能是一个挑战。例如,考虑以下数组:$arr = ['a' => 'abc'];我们如何有条件地添加 'b' => 'xyz'使用 array() 语句对此数组进行操作?在这种情况下,三元运算符不...
    编程 发布于2024-11-08
  • 从打字机到像素:CMYK、RGB 和构建色彩可视化工具的旅程
    从打字机到像素:CMYK、RGB 和构建色彩可视化工具的旅程
    当我还是个孩子的时候,我出版了一本关于漫画的粉丝杂志。那是在我拥有计算机之前很久——它是用打字机、纸和剪刀创建的! 粉丝杂志最初是黑白的,在我的学校复印的。随着时间的推移,随着它取得了更大的成功,我能够负担得起带有彩色封面的胶印! 然而,管理这些颜色非常具有挑战性。每个封面必须打印四次,每种颜色打印...
    编程 发布于2024-11-08
  • 如何将 Boehm 的垃圾收集器与 C++ 标准库集成?
    如何将 Boehm 的垃圾收集器与 C++ 标准库集成?
    集成 Boehm 垃圾收集器和 C 标准库要将 Boehm 保守垃圾收集器与 C 标准库集合无缝集成,有两种主要方法:重新定义运算符::new此方法涉及重新定义运算符::new以使用Boehm的GC。但是,它可能与现有 C 代码冲突,并且可能无法在不同编译器之间移植。显式分配器参数您可以使用而不是重...
    编程 发布于2024-11-08
  • 如何优化子集验证以获得顶级性能?
    如何优化子集验证以获得顶级性能?
    优化子集验证:确保每一位都很重要确定一个列表是否是另一个列表的子集的任务在编程中经常遇到。虽然交叉列表和比较相等性是一种简单的方法,但考虑性能至关重要,尤其是对于大型数据集。考虑到这种情况,需要考虑的一个关键因素是任何列表在多个测试中是否保持不变。由于您的场景中的其中一个列表是静态的,因此我们可以利...
    编程 发布于2024-11-08
  • 如何处理超出 MySQL BIGINT 限制的大整数?
    如何处理超出 MySQL BIGINT 限制的大整数?
    超出 MySQL BIGINT 限制的大整数处理MySQL 的 BIGINT 数据类型可能看起来是最广泛的整数表示形式,但是在处理时会出现限制超过 20 位的数字。超出 BIGINT 的选项边界当存储要求超出BIGINT的能力时,会出现两个选项:存储为VARCHAR: Twitter API建议将大...
    编程 发布于2024-11-08
  • 如何确保 Python Selenium 中加载多个元素?
    如何确保 Python Selenium 中加载多个元素?
    Python Selenium:确保​​多个元素加载通过 AJAX 处理动态加载的元素时,确认其外观可能具有挑战性。为了处理这种情况,我们将利用 Selenium 的 WebDriverWait 及其各种策略来确保多个元素的存在。所有元素的可见性:验证所有与特定选择器匹配的元素,我们可以使用visi...
    编程 发布于2024-11-08
  • 了解 JavaScript 中的标记模板文字
    了解 JavaScript 中的标记模板文字
    什么是标记模板文字? 带标签的模板文字涉及以函数为前缀的模板文字,称为标签。该函数可以处理和操作文字的内容。这是一个简单的例子: function tag(strings, ...values) { console.log(strings); console.log...
    编程 发布于2024-11-08
  • 二指针算法解释
    二指针算法解释
    我想解释一个简单有效的技巧,你可以在面试中处理数组、字符串、链表等时使用它。这也将提高你对这些数据的基础知识结构。 让我们从理论开始。该算法有两个常见用例: left/right 该算法的中心概念是有两个整数变量,它们将从字符串或数组的两侧移动。通常,人们称之为左和右。左边将从0索引移动到长度-1,...
    编程 发布于2024-11-08

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3