目錄
attributechangedCallback
>
首頁 web前端 css教學 通過創建自定義標籤來擴展HTML

通過創建自定義標籤來擴展HTML

Mar 02, 2025 am 09:45 AM

在本教程中,我將向您展示使用自定義標籤擴展HTML語言是多麼容易。自定義標籤可用於實現各種行為,因此它們是一種非常方便的編寫代碼並保持您的HTML文檔更簡單的方式。

可以進一步使用自定義標籤,查看我在使用Shadow dom的封裝自定義標籤的帖子。 < codingdude-gravatar>

。此自定義標籤將顯示特定電子郵件地址的Gravatar圖片。 

>

>

>< codingDudeGravatar>

是>無效的。這允許解析器能夠將常規元素與自定義標籤區分開。 自定義元素標籤名稱必須始終具有儀表板( - )。上面的代碼等同於以下內容:

如果您想創建一個自定義元素,該元素擴展了另一個HTML元素,則必須在domexception

>。

customElements.define("codingdude-gravatar", CodingDudeGravatar);<br>
登入後複製
登入後複製

  • 自定義元素中擴展本地元素。實例化自定義元素>> html元素的所有標準規則適用於自定義元素。就像標準元素一樣,您可以使用JavaScript在DOM中創建一個自定義元素,或在HTML中聲明。

    >在HTML中聲明自定義元素:>

    >
    <codingdude-gravatar></codingdude-gravatar><br>
    登入後複製
    登入後複製

    >

    var codingdudeGravatar = document.createElement('codingdude-gravatar');<br>codingdudeGravatar.addEventListener('click',function(e){});<br>
    登入後複製
    >

    使用JavaScript中的DOM中的擴展元素:

    <button is="codingdude-gravatar"><br>
    登入後複製

    5。在自定義標籤中添加標記
    var codingdudeGravatar = document.createElement('button', 'codingdude-gravatar');<br>
    登入後複製

    在自定義標籤中非常簡單。首先,您需要創建一個擴展父html元素的類。在我們的情況下,我們將擴展htmlelement ,我們將利用自定義標籤的innertext

    。請記住,在構造函數內部調用此

    指向創建的自定義元素。 這是一個簡單的概述。生命週期方法

    開始在自定義標籤中添加標記之前,您需要了解與自定義標籤相關的生命週期方法。有四個生命週期回調。

    class CodingDudeGravatar extends HTMLElement {<br>  constructor() {<br>    super()<br>    this.addEventListener('click', e => {<br>        alert('You Clicked Me!')<br>    });<br>    this.innerText="Hello There!"<br>  }<br>}<br>window.customElements.define('codingdude-gravatar', CodingDudeGravatar);<br>
    登入後複製
    >我們已經看到瞭如何使用ConnectedCallback

    。一旦將元素添加到文檔中,此檢查就會進行。我們將使用一個自定義標籤

    具有電子郵件

    屬性設置在自定義標籤中,屏幕將如下:
    class CodingDudeGravatar extends HTMLElement {<br>    constructor() {<br>    super(); // always call super() first in the constructor.<br>    ...<br>    }<br>    connectedCallback() {<br>    ...<br>    }<br>    disconnectedCallback() {<br>    ...<br>    }<br>    attributeChangedCallback(attrName, oldVal, newVal) {<br>    ...<br>    }<br>}<br>
    登入後複製
    :對於要觸發的屬性
    customElements.define("codingdude-gravatar", CodingDudeGravatar);<br>
    登入後複製
    登入後複製
    通過創建自定義標籤來擴展HTML

    attributechangedCallback

    。在我們的情況下,我們希望在自定義元素上的el.setAttribute('email','newemail')

    ,瀏覽器將觸發disconnectedCallback

    <codingdude-gravatar></codingdude-gravatar><br>
    登入後複製
    登入後複製

    >

    在我們的生命週期方法列表中的最後一個是el.remove()eyremove()

    >

    ,默認情況下,這些屬性將存在於自定義元素中。但是,可以修改這些屬性的行為。在大多數情況下,使用JavaScript類中的Getters和Setter用於控制屬性。 在以下演示中,可以在Codepen上的DDDEV(@divyadddev)中參見DDDEV(@DivyAddDev)的筆自定義標籤。

    >結論hooray!我們已經到了有關如何創建自定義元素的文章的結尾。現在,您應該能夠創建一個自定義元素並在HTML標記中使用它。嘗試一下!您會驚訝地發現可以完成多少工作。 這只是自定義元素工作方式的開始。在這一領域還有很多要探索和學習的東西。繼續觀看此空間,以獲取有關自定義元素及其高級概念的更多帖子。 >

    以上是通過創建自定義標籤來擴展HTML的詳細內容。更多資訊請關注PHP中文網其他相關文章!

  • 本網站聲明
    本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

    熱AI工具

    Undresser.AI Undress

    Undresser.AI Undress

    人工智慧驅動的應用程序,用於創建逼真的裸體照片

    AI Clothes Remover

    AI Clothes Remover

    用於從照片中去除衣服的線上人工智慧工具。

    Undress AI Tool

    Undress AI Tool

    免費脫衣圖片

    Clothoff.io

    Clothoff.io

    AI脫衣器

    Video Face Swap

    Video Face Swap

    使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

    熱門文章

    <🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌
    北端:融合系統,解釋
    3 週前 By 尊渡假赌尊渡假赌尊渡假赌

    熱工具

    記事本++7.3.1

    記事本++7.3.1

    好用且免費的程式碼編輯器

    SublimeText3漢化版

    SublimeText3漢化版

    中文版,非常好用

    禪工作室 13.0.1

    禪工作室 13.0.1

    強大的PHP整合開發環境

    Dreamweaver CS6

    Dreamweaver CS6

    視覺化網頁開發工具

    SublimeText3 Mac版

    SublimeText3 Mac版

    神級程式碼編輯軟體(SublimeText3)

    熱門話題

    Java教學
    1664
    14
    CakePHP 教程
    1423
    52
    Laravel 教程
    1321
    25
    PHP教程
    1269
    29
    C# 教程
    1249
    24
    如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 如何使用HTML,CSS和JavaScript創建動畫倒計時計時器 Apr 11, 2025 am 11:29 AM

    您是否曾經在項目上需要一個倒計時計時器?對於這樣的東西,可以自然訪問插件,但實際上更多

    HTML數據屬性指南 HTML數據屬性指南 Apr 11, 2025 am 11:50 AM

    您想了解的有關HTML,CSS和JavaScript中數據屬性的所有信息。

    當您看上去時,CSS梯度變得更好 當您看上去時,CSS梯度變得更好 Apr 11, 2025 am 09:16 AM

    我關注的一件事是Lea Verou&#039; s conic-Gradient()Polyfill的功能列表是最後一項:

    使Sass更快的概念證明 使Sass更快的概念證明 Apr 16, 2025 am 10:38 AM

    在一個新項目開始時,Sass彙編發生在眼睛的眨眼中。感覺很棒,尤其是當它與browsersync配對時,它重新加載

    靜態表單提供商的比較 靜態表單提供商的比較 Apr 16, 2025 am 11:20 AM

    讓我們嘗試在這裡造成一個術語:“靜態表單提供商”。你帶上html

    如何在WordPress主題中構建VUE組件 如何在WordPress主題中構建VUE組件 Apr 11, 2025 am 11:03 AM

    內聯式模板指令使我們能夠將豐富的VUE組件構建為對現有WordPress標記的逐步增強。

    php是A-OK用於模板 php是A-OK用於模板 Apr 11, 2025 am 11:04 AM

    PHP模板通常會因促進Subpar代碼而變得不良說唱,但這並不是這樣的情況。讓我們看一下PHP項目如何執行基本的

    三種代碼 三種代碼 Apr 11, 2025 pm 12:02 PM

    每次啟動一個新項目時,我都會將我正在查看的代碼分為三種類型,或者如果您願意的話。我認為這些類型可以應用於

    See all articles