cari
Rumahhujung hadapan webSoal Jawab bahagian hadapanBagaimana untuk menerangkan peristiwa sintetik tindak balas

Peristiwa sintetik React ialah objek acara yang mensimulasikan semua keupayaan peristiwa DOM asli dalam React, iaitu, pembalut silang penyemak imbas untuk peristiwa asli penyemak imbas, ia mentakrifkan peristiwa sintetik mengikut spesifikasi W3C, serasi dengannya semua pelayar, dan mempunyai antara muka yang sama seperti peristiwa asli pelayar. Dalam React, semua acara adalah sintetik dan bukan acara DOM asli, tetapi acara DOM boleh diperolehi melalui sifat "e.nativeEvent".

Bagaimana untuk menerangkan peristiwa sintetik tindak balas

Persekitaran pengendalian tutorial ini: sistem Windows 7, versi react18, komputer Dell G3.

1. Apakah itu peristiwa sintetik? berasaskan Mekanisme acara itu sendiri melaksanakan satu set mekanisme acara, termasuk pendaftaran acara, sintesis peristiwa, menggelegak acara, penghantaran acara, dll.

Dalam React, set mekanisme peristiwa ini dipanggil peristiwa sintetik

SyntheticEvent

Acara sintetik React (SyntheticEvent) ialah objek peristiwa yang React mensimulasikan semua keupayaan peristiwa DOM asli, iaitu, menyemak imbas silang bagi pelayar asli pembalut peranti acara. Ia mentakrifkan peristiwa sintetik mengikut spesifikasi W3C, serasi dengan semua penyemak imbas, dan mempunyai antara muka yang sama seperti peristiwa asli penyemak imbas. Contohnya,

Dalam React, semua peristiwa adalah sintetik dan bukan peristiwa DOM asli, tetapi peristiwa DOM boleh diperolehi melalui sifat e.nativeEvent. Contohnya:

const button = <button onClick={handleClick}>按钮</button>

Seperti yang anda lihat daripada di atas, peristiwa React dan peristiwa asli adalah sangat serupa, tetapi terdapat juga perbezaan tertentu:

const handleClick = (e) => console.log(e.nativeEvent);;
const button = <button>按钮</button>

Nama acara dinamakan berbeza
// 原生事件绑定方式
<button onclick="handleClick()">按钮命名</button>
      
// React 合成事件绑定方式
const button = <button onClick={handleClick}>按钮命名</button>
Fungsi pengendali acara ditulis secara berbeza
  • Walaupun onclick nampaknya terikat pada elemen DOM , tetapi sebenarnya, fungsi proksi acara tidak terikat secara langsung pada nod sebenar, tetapi semua peristiwa terikat pada lapisan paling luar struktur, dan peristiwa bersatu digunakan untuk memantau. [Cadangan berkaitan:
Tutorial Video Redis
// 原生事件 事件处理函数写法
<button onclick="handleClick()">按钮命名</button>
      
// React 合成事件 事件处理函数写法
const button = <button onClick={handleClick}>按钮命名</button>
,

Tutorial Pengaturcaraan]Pendengar acara ini mengekalkan pemetaan untuk menyimpan fungsi mendengar dan memproses acara di dalam semua komponen. Apabila komponen dipasang atau dinyahlekap, cuma masukkan atau alih keluar beberapa objek pada pendengar acara bersatu ini.

Apabila sesuatu peristiwa berlaku, ia mula-mula diproses oleh pendengar acara bersatu ini, dan kemudian fungsi pengendalian peristiwa sebenar ditemui dalam pemetaan dan dipanggil. Ini memudahkan pemprosesan acara dan mekanisme kitar semula, serta meningkatkan kecekapan.

2. Urutan pelaksanaan

Mengenai urutan pelaksanaan peristiwa sintetik React dan peristiwa asli, anda boleh melihat contoh berikut:

Jujukan output Untuk:

import  React  from &#39;react&#39;;
class App extends React.Component{

  constructor(props) {
    super(props);
    this.parentRef = React.createRef();
    this.childRef = React.createRef();
  }
  componentDidMount() {
    console.log("React componentDidMount!");
    this.parentRef.current?.addEventListener("click", () => {
      console.log("原生事件:父元素 DOM 事件监听!");
    });
    this.childRef.current?.addEventListener("click", () => {
      console.log("原生事件:子元素 DOM 事件监听!");
    });
    document.addEventListener("click", (e) => {
      console.log("原生事件:document DOM 事件监听!");
    });
  }
  parentClickFun = () => {
    console.log("React 事件:父元素事件监听!");
  };
  childClickFun = () => {
    console.log("React 事件:子元素事件监听!");
  };
  render() {
    return (
      <div ref={this.parentRef} onClick={this.parentClickFun}>
        <div ref={this.childRef} onClick={this.childClickFun}>
          分析事件执行顺序
        </div>
      </div>
    );
  }
}
export default App;

Kesimpulan berikut boleh dibuat:

原生事件:子元素 DOM 事件监听! 
原生事件:父元素 DOM 事件监听! 
React 事件:子元素事件监听! 
React 事件:父元素事件监听! 
原生事件:document DOM 事件监听!

React Semua peristiwa dipasang pada objek dokumen
  • Apabila elemen DOM sebenar mencetuskan acara, ia akan menggelembung ke objek dokumen dan kemudian memproses acara React
  • Jadi acara asli akan dilaksanakan dahulu, dan kemudian acara React akan diproses
  • Akhir sekali, acara yang dipasang pada dokumen sebenarnya dilaksanakan
  • Proses yang sepadan adalah seperti yang ditunjukkan dalam rajah :

Jadi saya fikir Untuk mengelakkan tingkah laku menggelegak dalam tempoh masa yang berbeza, gunakan kaedah yang berbeza, seperti berikut: Bagaimana untuk menerangkan peristiwa sintetik tindak balas

Untuk mengelakkan menggelegak antara peristiwa sintetik, gunakan e.stopPropagation()
  • Halang menggelegak peristiwa dan peristiwa sintetik pada dokumen paling luar, gunakan e.nativeEvent.stopImmediatePropagation()
  • Peristiwa bertindak balas Mekanisme diringkaskan seperti berikut:
  • Acara yang didaftarkan pada React akhirnya akan terikat pada DOM dokumen, bukannya DOM yang sepadan dengan komponen React (overhed memori dikurangkan kerana semua peristiwa terikat Pada dokumen, nod lain tidak mempunyai peristiwa terikat)
document.body.addEventListener(&#39;click&#39;, e => {   
    if (e.target && e.target.matches(&#39;div.code&#39;)) {  
        return;    
    }    
    this.setState({   active: false,    });   }); 
}

React sendiri melaksanakan satu set mekanisme menggelegak acara, jadi inilah sebabnya acara kami.stopPropagation() tidak sah.

Bertindak balas kesan kembali daripada komponen yang dicetuskan kepada komponen induk melalui baris gilir, dan kemudian memanggil panggilan balik yang ditakrifkan dalam JSX mereka
  • React telah satu set Peristiwa sintetik anda sendiri SyntheticEvent
  • (Perkongsian video pembelajaran:
  • Video Pengaturcaraan Asas
  • )

Atas ialah kandungan terperinci Bagaimana untuk menerangkan peristiwa sintetik tindak balas. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan
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
useState () vs usereducer (): memilih cangkuk yang tepat untuk keperluan negara andauseState () vs usereducer (): memilih cangkuk yang tepat untuk keperluan negara andaApr 24, 2025 pm 05:13 PM

PILISEUSESTATE () Forsimple, IndependentStateVariables; useUsereducer () forComplexStateLogicorWhenStededededSonPreviousState.1) useState () isIdealForsimpleupdatesliketogglingabooleanorupdatingAcounter.2)

Menguruskan Negeri dengan UseState (): Tutorial PraktikalMenguruskan Negeri dengan UseState (): Tutorial PraktikalApr 24, 2025 pm 05:05 PM

UseState lebih tinggi daripada komponen kelas dan penyelesaian pengurusan negeri yang lain kerana ia memudahkan pengurusan negeri, menjadikan kod lebih jelas, lebih mudah dibaca, dan selaras dengan sifat deklaratif React. 1) UseState membolehkan pemboleh ubah negeri diisytiharkan secara langsung dalam komponen fungsi, 2) ia mengingati negara semasa membuat semula melalui mekanisme cangkuk, 3) menggunakan useState untuk menggunakan pengoptimuman reaksi seperti menghafal untuk meningkatkan prestasi,

Bila Menggunakan UseState () dan Bila Mempertimbangkan Penyelesaian Pengurusan Negeri AlternatifBila Menggunakan UseState () dan Bila Mempertimbangkan Penyelesaian Pengurusan Negeri AlternatifApr 24, 2025 pm 04:49 PM

UseUsestate () forlocalComponentStatemanagement; pertimbangan yang tidak dapat dipertahankan, kompleksLogic, orperformanceissues.1) useState () isidealforsimple, localstate.2) useglobalStatesolutionsLikereduxorcontextForShorSharsharedState.3)

Komponen yang boleh diguna semula React: Meningkatkan Pengekalkan dan Kecekapan KodKomponen yang boleh diguna semula React: Meningkatkan Pengekalkan dan Kecekapan KodApr 24, 2025 pm 04:45 PM

ReusablecomponentsinreactenhanceCodeMaintainabilityandficiencybylowingdevelperstousethesamecomponentacrossdifferentpartsofanapplicationorprojects.1) merekaReduceredundancyandsimplifyupdates.2) mereka

Dom Maya di React: Meningkatkan Prestasi Melalui Kemas Kini CekapDom Maya di React: Meningkatkan Prestasi Melalui Kemas Kini CekapApr 24, 2025 pm 04:41 PM

Thevirtualdomisalightweightin-memorycopyoftherealealeusedbyreactooptimizeuiupdates.itboostsperformanceMinimizingDirectdomanipulationThoughaprocessofupdatingTheVirtualDomfirst, thenapplyingonlynectionarychangeSotheakualdom.

Integrasi HTML dan React: Panduan PraktikalIntegrasi HTML dan React: Panduan PraktikalApr 21, 2025 am 12:16 AM

HTML dan React boleh diintegrasikan dengan lancar melalui JSX untuk membina antara muka pengguna yang cekap. 1) Benamkan elemen HTML menggunakan JSX, 2) mengoptimumkan prestasi rendering menggunakan DOM maya, 3) mengurus dan menjadikan struktur HTML melalui komponen. Kaedah integrasi ini bukan sahaja intuitif, tetapi juga meningkatkan prestasi aplikasi.

React dan HTML: Memberi data dan acara pengendalianReact dan HTML: Memberi data dan acara pengendalianApr 20, 2025 am 12:21 AM

React dengan cekap menjadikan data melalui negeri dan prop, dan mengendalikan peristiwa pengguna melalui sistem peristiwa sintesis. 1) Gunakan UseState untuk menguruskan keadaan, seperti contoh kaunter. 2) Pemprosesan acara dilaksanakan dengan menambahkan fungsi dalam JSX, seperti klik butang. 3) Atribut utama diperlukan untuk membuat senarai, seperti komponen todolist. 4) Untuk pemprosesan borang, useState dan E.PreventDefault (), seperti komponen bentuk.

Sambungan backend: bagaimana reaksi berinteraksi dengan pelayanSambungan backend: bagaimana reaksi berinteraksi dengan pelayanApr 20, 2025 am 12:19 AM

React berinteraksi dengan pelayan melalui permintaan HTTP untuk mendapatkan, menghantar, mengemas kini dan memadam data. 1) Operasi Pengguna mencetuskan peristiwa, 2) Memulakan permintaan HTTP, 3) Respons Pelayan Proses, 4) Kemas kini Status Komponen dan Re-Render.

See all articles

Alat AI Hot

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.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat

Pelayar Peperiksaan Selamat ialah persekitaran pelayar selamat untuk mengambil peperiksaan dalam talian dengan selamat. Perisian ini menukar mana-mana komputer menjadi stesen kerja yang selamat. Ia mengawal akses kepada mana-mana utiliti dan menghalang pelajar daripada menggunakan sumber yang tidak dibenarkan.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.