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