8

Given an element contained in a shadow root, how can I get to the element that hosts the said shadow root? Is there a single way to accomplish this regardless of where an element is in the tree (i.e. given a reference to either element2 or element3, get the reference to element1)?

element1
└ #shadow-root
  └ element2
    └ element3
Supersharp
  • 29,002
  • 9
  • 92
  • 134
darrylyeo
  • 3,103
  • 20
  • 30

2 Answers2

12

For Shadow DOM v1, you may use the getRootNode() method.

Then get the host attribute:

event.target.getRootNode().host
Supersharp
  • 29,002
  • 9
  • 92
  • 134
0

You can keep iterating parentNode until you get the shadow root, and then get host.

function getHostElement(el) {
  while (el.parentNode) el = el.parentNode;
  return getShadowRoot(el).host;
}
var element1 = document.createElement('element1');
var element2 = document.createElement('element2');
var element3 = document.createElement('element3');
element2.appendChild(element3);
var shadowRoot = element1.createShadowRoot();
shadowRoot.appendChild(element2);
getHostElement(element3); // element1
Oriol
  • 274,082
  • 63
  • 437
  • 513