diff --git a/Libraries/LibHTML/DOM/Element.cpp b/Libraries/LibHTML/DOM/Element.cpp
index fefde6a4a8..2f339d7bf8 100644
--- a/Libraries/LibHTML/DOM/Element.cpp
+++ b/Libraries/LibHTML/DOM/Element.cpp
@@ -78,6 +78,7 @@ bool Element::has_class(const StringView& class_name) const
RefPtr Element::create_layout_node(const StyleProperties* parent_style) const
{
auto style = document().style_resolver().resolve_style(*this, parent_style);
+ const_cast(*this).m_resolved_style = style;
auto display = style->string_or_fallback(CSS::PropertyID::Display, "inline");
if (display == "none")
@@ -139,6 +140,7 @@ void Element::recompute_style()
return;
ASSERT(parent_layout_node);
auto style = document().style_resolver().resolve_style(*this, &parent_layout_node->style());
+ m_resolved_style = style;
if (!layout_node()) {
if (style->string_or_fallback(CSS::PropertyID::Display, "inline") == "none")
return;
diff --git a/Libraries/LibHTML/DOM/Element.h b/Libraries/LibHTML/DOM/Element.h
index 4444bd497a..cf53f8221a 100644
--- a/Libraries/LibHTML/DOM/Element.h
+++ b/Libraries/LibHTML/DOM/Element.h
@@ -56,6 +56,8 @@ public:
String name() const { return attribute("name"); }
+ const StyleProperties* resolved_style() const { return m_resolved_style.ptr(); }
+
private:
RefPtr create_layout_node(const StyleProperties* parent_style) const override;
@@ -64,6 +66,8 @@ private:
String m_tag_name;
Vector m_attributes;
+
+ RefPtr m_resolved_style;
};
template<>