ホームページ ウェブフロントエンド CSSチュートリアル 解き放たれたカスタム要素: DominandocustomElements.define() と .get() は、Jedi のフロントエンドと同じです!

解き放たれたカスタム要素: DominandocustomElements.define() と .get() は、Jedi のフロントエンドと同じです!

Nov 01, 2024 am 08:59 AM

Custom Elements Unleashed: Dominando customElements.define() e .get() como um Jedi do Front-end!

開発者の皆さん! Custom Elements の世界の秘密を解き明かす準備はできていますか?今日は、すべてのフロントエンド ジェダイが習得する必要がある秘密兵器である、customElements.define() とcustomElements.get() の機能を深く掘り下げていきます。

?️customElements.define(): 自分のポケモンを作成します... つまり、エレメントです!

あなたが気の狂ったフロントエンド科学者で、独自の HTML クリーチャーを作成したいと考えていると想像してください。そこで、customElements.define() が登場します。ミュウツーのクローンマシンに似ていますが、Web 要素用です!

class ElementoTopzera extends HTMLElement {
  constructor() {
    super();
    this.innerHTML = `<p>Eu sou incrível e customizado!</p>`;
  }
}

customElements.define('elemento-topzera', ElementoTopzera);
ログイン後にコピー

これで、HTML のネイティブであるかのように要素を使用できるようになります。

<elemento-topzera></elemento-topzera>
ログイン後にコピー

ドーン! ?あなたはちょうど DOM 内に生命を創造したところです!

?‍♂️ 開発者の友人を感動させる魔法の例

  1. カウンターボタン クリックされた回数をカウントするボタンを想像してください。これは、デバッグの忍耐力を示すスコアカードのようなものです。
class BotaoContador extends HTMLElement {
  constructor() {
    super();
    this.count = 0;
    this.innerHTML = `
      <button>Cliques: <span>0</span></button>
    `;
    this.addEventListener('click', () => {
      this.count++;
      this.querySelector('span').textContent = this.count;
    });
  }
}

customElements.define('botao-contador', BotaoContador);
ログイン後にコピー
  1. プロフィールカード RPGのキャラクターよりカスタマイズ性の高いプロフィールカード!
class CardPerfil extends HTMLElement {
  constructor() {
    super();
    const nome = this.getAttribute('nome') || 'Dev Anônimo';
    const skill = this.getAttribute('skill') || 'Café++';

    this.innerHTML = `
      <div style="border: 2px solid #333; padding: 10px; margin: 10px;">
        <h2>${nome}</h2>
        <p>Skill Suprema: ${skill}</p>
      </div>
    `;
  }
}

customElements.define('card-perfil', CardPerfil);
ログイン後にコピー

次のように使用します。

<card-perfil nome="ZézimDev" skill="Bug Hunter"></card-perfil>
ログイン後にコピー

?️‍♂️customElements.get(): 要素のシャーロック ホームズ

それでは、カスタム要素がすでに存在するかどうかを調べたい場合はどうすればよいでしょうか?そこで、Web コンポーネント界の私立探偵、customElements.get() の出番です!

const ElementoTopzera = customElements.get('elemento-topzera');

if (ElementoTopzera) {
  console.log('Elemento encontrado! Hora do show!');
  // Faz alguma mágica aqui
} else {
  console.log('404 Elemento Not Found');
}
ログイン後にコピー

⁉ 80 年代のアーケードよりクールなユースケース

  1. コンポーネントの遅延読み込み 必要な場合にのみコンポーネントをロードすることで、プログラマがセミコロンの位置を覚えようとするよりも多くのメモリを節約できます。
function carregaComponenteSeNecessario(nomeElemento) {
  if (!customElements.get(nomeElemento)) {
    import(`./components/${nomeElemento}.js`)
      .then(() => console.log(`${nomeElemento} carregado e pronto pra ação!`))
      .catch(err => console.error(`Oops, deu ruim ao carregar ${nomeElemento}`, err));
  }
}

carregaComponenteSeNecessario('super-tabela');
ログイン後にコピー
  1. セキュリティチェック 悪意のある要素があなたになりすまそうとしていないか確認してください。
function elementoSeguro(nomeElemento) {
  const elemento = customElements.get(nomeElemento);
  if (elemento && elemento.prototype instanceof HTMLElement) {
    console.log('Elemento verificado e aprovado! ?');
    return true;
  }
  console.warn('Elemento suspeito detectado! ?');
  return false;
}

elementoSeguro('botao-contador'); // true, se definido anteriormente
elementoSeguro('virus-malicioso'); // false, espero eu! ?
ログイン後にコピー

?フロントエンドのジェダイマスターからの教訓

  1. 一意の名前: ソーシャル ネットワークのユーザー名などの要素名を選択します - 一意で、真ん中にダッシュが付いています!
  2. 前に確認してください: DOM の時空に混乱が生じないように、定義する前に常にcustomElements.get() を使用してください。
  3. 賢く拡張してください: 追加のスーパーパワーが必要ですか?ネイティブ要素を拡張します。
   class SuperButton extends HTMLButtonElement {
     // Código supimpa aqui
   }
   customElements.define('super-button', SuperButton, { extends: 'button' });
ログイン後にコピー

?エレメントのマスターになろう!

customElements.define() とcustomElements.get() を使用すると、ストリーマーのセットアップよりもさらにカスタマイズされた Web を作成する準備が整います。覚えておいてください: 大きな力には、素晴らしいコンポーネントを作成する大きなチャンスが伴います!

あとはあなた次第です!要素を作成して Web に革命を起こしましょう!そして、もしバグに巻き込まれたら、深呼吸して、「ライナス・トーバルズだったらどうするだろう?」と考えてください。 ??

この多元的な可能性をさらに深く掘り下げてみませんか? MDN の公式カスタム要素ドキュメントを参照してください。まるでフロントエンドウィザードのグリモワールのようです。 ?✨

どうしたの、開発者?独自の要素を作成することに興奮していますか?あなたが作成するクレイジーな要素をコメントで共有してください!おそらく次回は を行うことになるでしょう。それはコードをコーヒーに変えます! ☕?

コードがいつもあなたのそばにありますように! ??‍?

以上が解き放たれたカスタム要素: DominandocustomElements.define() と .get() は、Jedi のフロントエンドと同じです!の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

静的フォームプロバイダーの比較 静的フォームプロバイダーの比較 Apr 16, 2025 am 11:20 AM

ここでは、「静的フォームプロバイダー」という用語を埋めてみましょう。あなたはあなたのHTMLを持ってきます

SASSをより速くするための概念の証明 SASSをより速くするための概念の証明 Apr 16, 2025 am 10:38 AM

新しいプロジェクトの開始時に、SASSコンピレーションは瞬く間に起こります。これは、特にbrowsersyncとペアになっている場合は素晴らしい気分です。

毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 毎週のプラットフォームニュース:HTMLロード属性、主なARIA仕様、およびIFRAMEからShadowDOMへの移動 Apr 17, 2025 am 10:55 AM

今週のプラットフォームニュースのラウンドアップで、Chromeは、Web開発者のロード、アクセシビリティ仕様、およびBBCの動きのための新しい属性を導入します

HTMLダイアログ要素を使用したいくつかの実践 HTMLダイアログ要素を使用したいくつかの実践 Apr 16, 2025 am 11:33 AM

これは私が初めてHTML要素を見ていることです。私はしばらくの間それを知っていましたが、まだスピンしていませんでした。かなりクールです

ペーパーフォーム ペーパーフォーム Apr 16, 2025 am 11:24 AM

購入またはビルドは、テクノロジーの古典的な議論です。自分で物を構築することは、あなたのクレジットカードの請求書にはラインアイテムがないため、安価に感じるかもしれませんが

「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? 「ポッドキャストにサブスクライブ」リンクはどこにすべきですか? Apr 16, 2025 pm 12:04 PM

しばらくの間、iTunesはポッドキャストの大きな犬だったので、「ポッドキャストにサブスクライブ」をリンクした場合:

毎週のプラットフォームニュース:テキスト間隔のブックマークレット、トップレベルの待望、新しいアンプロードインジケーター 毎週のプラットフォームニュース:テキスト間隔のブックマークレット、トップレベルの待望、新しいアンプロードインジケーター Apr 17, 2025 am 11:26 AM

今週のラウンドアップ、タイポグラフィを検査するための便利なブックマークレットである。

独自の非JavaScriptベースの分析をホストするためのオプション 独自の非JavaScriptベースの分析をホストするためのオプション Apr 15, 2025 am 11:09 AM

サイトの訪問者と使用データを追跡するのに役立つ分析プラットフォームがたくさんあります。おそらく、特にGoogleアナリティクスが広く使用されています

See all articles