摘要:從中隱藏內(nèi)容模板中的內(nèi)容并不能視為的一部分,當我們查詢節(jié)點時,絕對不會返回模板的節(jié)點。使用模板時,將模板內(nèi)容插入到中即可。這顆子樹形成了自己的閉合空間,比如子樹可以包含與父文檔中重復(fù)的和樣式,而不會相沖突。
原生模板的優(yōu)勢
延遲了資源加載
延遲了加載和處理模板所引用的資源的時機,這樣,用戶就能夠在模板中使用任意多的資源,卻不阻礙頁面的渲染。
延遲了渲染內(nèi)容
無論模板在什么位置,瀏覽器不會把模板中的內(nèi)容直接渲染出來。開發(fā)者可以將模板放在頁面中的任意位置,然后根據(jù)具體的情形選擇模板去渲染,而不必切換模板的display屬性,或者擔心由于解析不需要的模板內(nèi)容而帶來的開銷。
從DOM中隱藏內(nèi)容
模板中的內(nèi)容并不能視為DOM的一部分,當我們查詢DOM節(jié)點時,絕對不會返回模板的節(jié)點。這樣,模板就不會拖慢DOM節(jié)點的查詢速度。模板終點內(nèi)容在激活之前都可以視為隱藏的。
原生模板的用法在標簽中編寫模板,編寫好的模板可以被插入到head body frameset等標簽中,或者他們的任意后代標簽中。
使用模板時,將模板內(nèi)容插入到DOM中即可。
首先獲得對模板節(jié)點的引用
var template = document.querySelector("#atcq")
然后創(chuàng)建Shadow DOM,之后將模板中的內(nèi)容填充到根元素中
var root = document.querySelector("#atcq-root").createShadowRoot() root.appendChild(template.content)Shadow DOM簡介
shadow-dom 其實是瀏覽器的一種能力,它允許在瀏覽器渲染文檔的時候向其中的 Dom 結(jié)構(gòu)中插入一棵 DOM 元素子樹,但是特殊的是,shadow DOM 子樹并不在主 DOM樹中。這顆子樹形成了自己的『閉合空間』,比如shadow DOM子樹可以包含與父文檔中重復(fù)的ID和樣式,而不會相沖突。
參考Shadow DOM v1:獨立的網(wǎng)絡(luò)組件
影子DOM
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/51956.html
摘要:從中隱藏內(nèi)容模板中的內(nèi)容并不能視為的一部分,當我們查詢節(jié)點時,絕對不會返回模板的節(jié)點。使用模板時,將模板內(nèi)容插入到中即可。這顆子樹形成了自己的閉合空間,比如子樹可以包含與父文檔中重復(fù)的和樣式,而不會相沖突。 原生模板的優(yōu)勢 延遲了資源加載 延遲了加載和處理模板所引用的資源的時機,這樣,用戶就能夠在模板中使用任意多的資源,卻不阻礙頁面的渲染。 延遲了渲染內(nèi)容 無論模板在什么位置,瀏覽器不...
摘要:此即如何實現(xiàn)局部樣式化的原理。這是一個絕佳的方式,開發(fā)者可以在組件內(nèi)部封裝響應(yīng)用戶交互或者狀態(tài)的行為,然后基于宿主元素來樣式化內(nèi)部節(jié)點。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 這是 JavaScript 工作原理的第十七章。 showImg(https://segmentfault.com/img/remote/1460000...
摘要:向影子樹添加的任何內(nèi)容都將成為宿主元素的本地元素,包括,這就是影子實現(xiàn)樣式作用域的方式。 這是專門探索 JavaScript 及其所構(gòu)建的組件的系列文章的第 17 篇。 想閱讀更多優(yōu)質(zhì)文章請猛戳GitHub博客,一年百來篇優(yōu)質(zhì)文章等著你! 如果你錯過了前面的章節(jié),可以在這里找到它們: JavaScript 是如何工作的:引擎,運行時和調(diào)用堆棧的概述! JavaScript 是如何工作...
摘要:若自定義元素標簽名稱不可用則摒棄??傊?,自定義元素讓開發(fā)者的代碼更易理解和維護,并分割為小型,可復(fù)用及可封裝的模塊。被稱為自定義元素接口,雖然現(xiàn)在仍然可用,但是已經(jīng)被棄用并被認為是糟糕的實現(xiàn)。 原文請查閱這里,略有刪減,本文采用知識共享署名 4.0 國際許可協(xié)議共享,BY Troland。 這是 JavaScript 工作原理第十九章。 概述 在 前述文章中,我們介紹了 Shadow ...
閱讀 1915·2021-11-24 09:39
閱讀 2142·2021-09-22 15:50
閱讀 2018·2021-09-22 14:57
閱讀 707·2021-07-28 00:13
閱讀 1072·2019-08-30 15:54
閱讀 2365·2019-08-30 15:52
閱讀 2690·2019-08-30 13:07
閱讀 3793·2019-08-30 11:27