Jadual Kandungan
Apa itu bayangan dom?
1. Melampirkan akar bayangan
2. Gaya di dalam bayangan dom
3. Membuat komponen web yang boleh diguna semula
4. Menggunakan slot untuk pengedaran kandungan
Faedah utama
Batasan untuk diingat
Rumah hujung hadapan web tutorial js Cara Menggunakan Dom Shadow di JavaScript

Cara Menggunakan Dom Shadow di JavaScript

Sep 20, 2025 am 12:27 AM

Gunakan kaedah lampiran () untuk melampirkan dom bayangan ke elemen hos, dan pilih 'buka' ke corak untuk mengakses akar bayangan; 2. Tambah tag dan tag gaya dalam akar bayang -bayang untuk mencapai pengasingan gaya; 3. Buat komponen yang boleh diguna semula dalam kombinasi dengan unsur -unsur tersuai, mulakan bayang -bayang dalam pembina dan mengikat peristiwa; 4. Gunakan tag slot untuk membolehkan kandungan luaran dimasukkan, menyokong slot lalai dan dinamakan untuk pengedaran kandungan; Shadow Dom menyediakan enkapsulasi gaya dan struktur untuk mengelakkan konflik global dan memudahkan pembinaan komponen web yang bebas dan boleh diguna semula.

Cara Menggunakan Dom Shadow di JavaScript

Menggunakan Shadow Dom di JavaScript membolehkan anda merangkumi gaya dan markup dalam elemen DOM, menjadikannya terpencil dari seluruh halaman. Ini amat berguna untuk membina komponen web yang boleh diguna semula. Inilah cara menggunakannya dengan berkesan.

Cara Menggunakan Dom Shadow di JavaScript

Apa itu bayangan dom?

The Shadow Dom adalah ciri penyemak imbas yang membolehkan anda melampirkan pokok dom tersembunyi, berasingan ke elemen. Pokok ini diberikan secara berasingan dari dokumen utama DOM, dan struktur dalaman, gaya, dan tingkah laku dalamannya dan tidak mengganggu seluruh halaman.


1. Melampirkan akar bayangan

Untuk menggunakan Shadow Dom, anda perlu melampirkan akar bayangan ke elemen hos menggunakan kaedah attachShadow() .

Cara Menggunakan Dom Shadow di JavaScript
 // Buat elemen tersuai atau gunakan yang ada
const host = document.createElement ('div');

// Lampirkan akar bayangan dengan mod 'buka'
const shadowroot = host.attachshadow ({mod: 'buka'});

// sekarang anda boleh menambah kandungan ke akar bayangan
Shadowroot.innerHtml = &#39;<p> Ini berada di dalam Shadow Dom </p>&#39;;
  • mode: &#39;open&#39; bermaksud akar bayangan boleh diakses dari JavaScript melalui element.shadowRoot .
  • mode: &#39;closed&#39; menyembunyikan akar bayangan - shadowRoot akan kembali null , menjadikannya tidak dapat diakses dari luar.

Nota: &#39;closed&#39; jarang digunakan dan tidak disokong sepenuhnya atau benar -benar selamat dalam amalan, jadi &#39;open&#39; lebih disukai.


2. Gaya di dalam bayangan dom

Gaya yang ditakrifkan di dalam akar bayangan tidak bocor, dan gaya luaran biasanya tidak menjejaskan unsur -unsur di dalam (dengan beberapa pengecualian seperti sifat yang diwarisi).

Cara Menggunakan Dom Shadow di JavaScript
 Shadowroot.innerHtml = `
  <yaya>
    p {
      Warna: Biru;
      font-family: sans-serif;
    }
  </gaya>
  <p> hello dari shadow dom! </p>
`;

Gaya scoped ini menghalang konflik CSS - manfaat utama apabila membina komponen yang boleh diguna semula.


3. Membuat komponen web yang boleh diguna semula

Kuasa sebenar datang apabila menggabungkan Shadow Dom dengan unsur -unsur tersuai.

 kelas myComponent memanjangkan htmlelement {
  pembina () {
    super ();

    // Lampirkan akar bayangan
    this.shadow = this.attachshadow ({mod: &#39;buka&#39;});

    // Membuat kandungan
    this.shadow.innerHtml = `
      <yaya>
        butang {
          Latar Belakang: #007BFF;
          Warna: Putih;
          Sempadan: Tiada;
          Padding: 10px;
          Radius sempadan: 4px;
          kursor: penunjuk;
        }
        butang: hover {
          Latar Belakang: #0056B3;
        }
      </gaya>
      <utton> klik saya </butang>
    `;
  }

  connectedCallback () {
    Const Button = This.Shadow.QuerySelector (&#39;Button&#39;);
    Button.AdDeventListener (&#39;klik&#39;, () => {
      console.log (&#39;Butang diklik di dalam Shadow Dom!&#39;);
    });
  }
}

// Daftarkan elemen tersuai
customElements.define (&#39;My-Component&#39;, MyComponent);

Sekarang anda boleh menggunakannya di HTML:

 </my-component> </my-component>

Butang dan gayanya benar -benar terpencil.


4. Menggunakan slot untuk pengedaran kandungan

Anda boleh membenarkan kandungan luaran diproyeksikan ke dalam komponen bayangan anda menggunakan <slot> .

 this.shadow.innerHtml = `
  <dana>
    <h3> Tajuk Komponen </h3>
    <slot> </slot> <!-ini akan diisi dengan kandungan dom cahaya->
  </div>
`;

Kemudian gunakannya seperti:

 <yy-component>
  <p> Kandungan ini muncul di dalam slot. </P>
</my-component>

Anda juga boleh menggunakan slot bernama untuk lebih banyak kawalan:

 <slot name = "header"> </slot>
<slot name = "body"> </slot>

Dan dalam cahaya dom:

 <span slot = "header"> header saya </span>
<span slot = "badan"> Kandungan utama di sini </span>

Faedah utama

  • Enkapsulasi : Gaya dan markup terpencil.
  • Mengelakkan konflik CSS : Tidak lagi bimbang tentang pertempuran gaya global.
  • Komponen yang boleh diguna semula : Membina elemen UI yang serba lengkap.
  • Kod bersih : Pemisahan logik antara dalaman komponen dan seluruh aplikasi.

Batasan untuk diingat

  • Anda tidak boleh secara langsung gaya Shadow Dom Elements dari luar CSS.
  • Peristiwa dari dalam bayang -bayang dom mungkin perlu ditangani dengan teliti (mereka biasanya gelembung melalui sempadan bayangan).
  • Debugging boleh menjadi lebih rumit kerana kandungannya tersembunyi secara lalai di DevTools melainkan anda membolehkan "Tunjukkan ejen pengguna Shadow Dom".

Menggunakan Shadow Dom adalah mudah apabila anda memahami asas -asasnya. Campurkannya dengan elemen tersuai dan templat HTML untuk komponen yang berkuasa dan dikekalkan. Pada asasnya, ia memberi anda kotak pasir yang bersih untuk membina UI web modular.

Atas ialah kandungan terperinci Cara Menggunakan Dom Shadow di JavaScript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Penapisan Multi-Condition JavaScript: Melaksanakan penapisan produk dinamik berdasarkan dan/atau logik Penapisan Multi-Condition JavaScript: Melaksanakan penapisan produk dinamik berdasarkan dan/atau logik Aug 22, 2025 am 10:00 AM

Tutorial ini memperkenalkan secara terperinci bagaimana menggunakan JavaScript untuk melaksanakan fungsi penapisan dinamik pelbagai syarat, yang membolehkan pengguna menapis produk berdasarkan pelbagai atribut seperti warna dan saiz. Melalui struktur HTML yang jelas dan contoh kod JavaScript, artikel menunjukkan cara mengendalikan dan atau logik secara fleksibel untuk memenuhi keperluan penapisan pengguna yang kompleks dan memberikan cadangan pengoptimuman.

Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Mengoptimumkan pengendalian acara lompat luaran dinamik di tetingkap pop timbul jQuery Sep 01, 2025 am 11:48 AM

Artikel ini bertujuan untuk menyelesaikan masalah mengalihkan butang redirect pautan luaran dalam tetingkap pop-up jQuery menyebabkan kesilapan lompat. Apabila pengguna mengklik pelbagai pautan luaran dalam penggantian, butang lompat di pop timbul mungkin selalu menunjuk pada pautan pertama yang diklik. Penyelesaian teras adalah dengan menggunakan kaedah off ('klik') untuk membatalkan pengendali acara lama sebelum setiap mengikat peristiwa baru, memastikan bahawa tingkah laku lompat sentiasa menunjuk kepada URL sasaran terkini, dengan itu mencapai pengalihan pautan yang tepat dan terkawal.

Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Bagaimana anda memilih elemen dengan atribut data dalam JavaScript? Aug 30, 2025 am 01:57 AM

Anda boleh memilih elemen dengan atribut data dalam JavaScript melalui pemilih atribut CSS, dan gunakan document.QuerySelector () atau document.QuerySelectorAll () kaedah untuk mencapai matlamat ini. 1. Gunakan [data-attribute] untuk memilih elemen dengan atribut data yang ditentukan (sebarang nilai); 2. Gunakan [data-attribute = "nilai"] untuk memilih elemen yang nilai atributnya sesuai; 3. Akses atribut data melalui elemen.dataset, di mana data-us-id sepadan dengan dataset.userid (ganti

Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Pytest dan Selenium: Strategi pelaksanaan untuk ujian yang didorong oleh data dinamik Aug 30, 2025 am 06:00 AM

Artikel ini bertujuan untuk menyelesaikan masalah yang @pytest.mark.parametrize decorator tidak dapat secara langsung mengendalikan data yang dijana pada runtime apabila menggunakan pytest dan selenium untuk ujian yang didorong data dinamik. Kami akan meneroka batasan pytest.mark.parametrize secara mendalam, dan memperkenalkan secara terperinci bagaimana untuk melaksanakan ujian parameter secara anggun berdasarkan pemerolehan data dinamik selenium melalui Pytest's PYTest_Generate_Tests Hook berfungsi untuk memastikan fleksibiliti dan kecekapan kes ujian.

Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Bina kaunter JavaScript berjalan dengan hari bekerja dan waktu bekerja Aug 31, 2025 am 06:30 AM

Artikel ini memperincikan bagaimana untuk membina kaunter masa yang tepat menggunakan JavaScript. Kaunter itu bertambah sekali seminit, tetapi hanya berjalan dalam hari kerja pratetap (Isnin hingga Jumaat) dan jam kerja (seperti 6 pagi hingga 8 malam). Ia boleh menjeda kenaikan semasa waktu tidak bekerja tetapi memaparkan nilai semasa dan menetapkan semula secara automatik pada hari pertama setiap bulan, memastikan ketepatan dan fleksibiliti logik pengiraan.

Mengoptimumkan Rendering Komponen React: Selesaikan masalah yang disebabkan oleh tetikus yang melayang Mengoptimumkan Rendering Komponen React: Selesaikan masalah yang disebabkan oleh tetikus yang melayang Aug 22, 2025 pm 01:36 PM

Artikel ini bertujuan untuk menyelesaikan isu-isu yang lebih baik yang dicetuskan oleh Onmouseover dalam aplikasi React. Dengan menggantikan OnMouseOver dengan OnMouseEnter dan digabungkan dengan OnMouseout dengan OnMouseleave, anda boleh mengurangkan komponen yang tidak perlu membuat semula dan meningkatkan prestasi aplikasi, terutamanya apabila berurusan dengan banyak komponen. Artikel ini akan menyediakan kod sampel dan penjelasan terperinci untuk membantu pemaju memahami dan menggunakan teknik pengoptimuman ini.

js mendapat ketinggian dan lebar elemen js mendapat ketinggian dan lebar elemen Aug 22, 2025 pm 04:16 PM

Useclientwidth/clientheightforvisiblecontentareaincludingpadding; 2.useOffsetWidth/offsetheightfortotalrenderedSizeIncludingContent, danborder;

Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Bagaimana unsur -unsur DOM yang dibuat secara dinamik diakses dan dikendalikan oleh skrip yang dimuatkan Aug 30, 2025 am 11:57 AM

Artikel ini menerangkan bagaimana skrip JavaScript dapat diakses dengan berkesan dan dimanipulasi apabila ia dimuatkan dan dilaksanakan sebelum penciptaan elemen DOM dalam pembangunan web. Kami akan memperkenalkan tiga strategi teras: secara langsung lulus rujukan elemen melalui nilai pulangan fungsi, menggunakan peristiwa tersuai untuk mencapai komunikasi antara modul, dan menggunakan MutationObserver untuk mendengar perubahan struktur DOM. Kaedah ini dapat membantu pemaju menyelesaikan cabaran antara masa pelaksanaan JavaScript dan pemuatan kandungan dinamik, memastikan skrip dapat mengendalikan unsur-unsur dengan betul, seperti menjadikannya drag-mampu.

See all articles