-
Notifications
You must be signed in to change notification settings - Fork 3.2k
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Update declarative Shadow DOM opt-in mechanics
The issue thread [1] has had more discussion, after the initial draft of declarative Shadow DOM opt-in landed [2]. This CL implements those bits of feedback. In particular: - There is no public allowDeclarativeShadowDom state available on Document or DocumentFragment. - All APIs use call parameters to avoid state, with the exception of DOMParser. - innerHTML no longer supports Declarative Shadow DOM. - A new setInnerHTML() function allows opt-in access to DSD. - Several of the more obscure APIs do not have an opt-in for declarative Shadow DOM, such as XHR, createContextualFragment, and document.write. - The sandbox flag has been removed from iframes completely. The new plan is to use DocumentPolicy to enable declarative Shadow DOM for iframes. For now, iframes do not support declarative Shadow DOM. - allowDeclarativeShadowDOM has become allowShadowRoot. [1] whatwg/dom#912 (comment) [2] https://chromium-review.googlesource.com/c/chromium/src/+/2513525 Bug: 1042130 Change-Id: I3a2becf2a113cc8647b29077d2efea1c990d4547
- Loading branch information
1 parent
005f922
commit 6cdff1f
Showing
4 changed files
with
113 additions
and
107 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,40 @@ | ||
<!DOCTYPE html> | ||
<title>getInnerHTML </title> | ||
<link rel='author' title='Mason Freed' href='mailto:[email protected]'> | ||
<link rel='help' href='https://github.com/whatwg/dom/issues/831'> | ||
<script src='/resources/testharness.js'></script> | ||
<script src='/resources/testharnessreport.js'></script> | ||
<script src='../resources/shadow-dom-utils.js'></script> | ||
|
||
<body> | ||
<script> | ||
function testElementType(allowsShadowDom, elementType) { | ||
var t = test(t => { | ||
// Create and attach element | ||
const wrapper = document.createElement('div'); | ||
t.add_cleanup(function() { wrapper.remove(); }); | ||
document.body.appendChild(wrapper); | ||
|
||
const html = `<${elementType}><template shadowroot="open"><slot></slot></template><span></span></${elementType}>`; | ||
wrapper.setInnerHTML(html, {allowShadowRoot: true}); | ||
if (allowsShadowDom) { | ||
// Retrieve shadow root | ||
assert_true(!!wrapper.firstElementChild.shadowRoot,'No shadow root found'); | ||
} else { | ||
const leftover = wrapper.firstElementChild.firstElementChild; | ||
assert_true(wrapper.firstElementChild.childElementCount == 0 || leftover instanceof HTMLTemplateElement,'Template should be left over (or no children)'); | ||
} | ||
}, `setInnerHTML() on <${elementType}>${allowsShadowDom ? `, with declarative Shadow DOM.` : ''}`); | ||
} | ||
|
||
function runAllTests() { | ||
const allElements = HTML5_ELEMENT_NAMES.filter(item => item !== 'body'); | ||
const safelisted = ATTACHSHADOW_SAFELISTED_ELEMENTS; | ||
for (const elementName of allElements) { | ||
testElementType(safelisted.includes(elementName), elementName); | ||
} | ||
} | ||
|
||
runAllTests(); | ||
|
||
</script> |