


Bagaimana 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".
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 SyntheticEventAcara 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 onClick={handleClick}>按钮</button>
// 原生事件绑定方式 <button onclick="handleClick()">按钮命名</button> // React 合成事件绑定方式 const button = <button onClick={handleClick}>按钮命名</button>
- 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:
// 原生事件 事件处理函数写法 <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 'react'; 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 事件监听!
- 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:
- Halang menggelegak peristiwa dan peristiwa sintetik pada dokumen paling luar, gunakan e.nativeEvent.stopImmediatePropagation()
- < . 3. Ringkasan 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('click', e => { if (e.target && e.target.matches('div.code')) { 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!

Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas



Cara membina aplikasi sembang masa nyata menggunakan React dan WebSocket Pengenalan: Dengan perkembangan pesat Internet, komunikasi masa nyata telah menarik lebih banyak perhatian. Apl sembang langsung telah menjadi sebahagian daripada kehidupan sosial dan kerja moden. Artikel ini akan memperkenalkan cara membina aplikasi sembang masa nyata yang ringkas menggunakan React dan WebSocket, dan memberikan contoh kod khusus. 1. Persediaan teknikal Sebelum mula membina aplikasi sembang masa nyata, kita perlu menyediakan teknologi dan alatan berikut: React: satu untuk membina

Bertindak balas panduan pemisahan bahagian hadapan dan hujung belakang: Bagaimana untuk mencapai penyahgandingan bahagian hadapan dan belakang serta penggunaan bebas, contoh kod khusus diperlukan Dalam persekitaran pembangunan web hari ini, pemisahan bahagian hadapan dan belakang telah menjadi satu trend . Dengan mengasingkan kod hadapan dan belakang, kerja pembangunan boleh dibuat lebih fleksibel, cekap dan memudahkan kerjasama pasukan. Artikel ini akan memperkenalkan cara menggunakan React untuk mencapai pemisahan bahagian hadapan dan belakang, seterusnya mencapai matlamat penyahgandingan dan penggunaan bebas. Pertama, kita perlu memahami apa itu pemisahan bahagian hadapan dan belakang. Dalam model pembangunan web tradisional, bahagian hadapan dan bahagian belakang digabungkan

Cara menggunakan React dan Flask untuk membina aplikasi web yang ringkas dan mudah digunakan Pengenalan: Dengan perkembangan Internet, keperluan aplikasi web menjadi semakin pelbagai dan kompleks. Untuk memenuhi keperluan pengguna untuk kemudahan penggunaan dan prestasi, semakin penting untuk menggunakan tindanan teknologi moden untuk membina aplikasi rangkaian. React dan Flask ialah dua rangka kerja yang sangat popular untuk pembangunan bahagian hadapan dan belakang, dan ia berfungsi dengan baik bersama-sama untuk membina aplikasi web yang ringkas dan mudah digunakan. Artikel ini akan memperincikan cara memanfaatkan React dan Flask

Panduan Reka Bentuk Responsif React: Cara Mencapai Kesan Susun Adaptif Bahagian Hadapan Dengan populariti peranti mudah alih dan permintaan pengguna yang semakin meningkat untuk pengalaman berbilang skrin, reka bentuk responsif telah menjadi salah satu pertimbangan penting dalam pembangunan bahagian hadapan moden. React, sebagai salah satu rangka kerja bahagian hadapan yang paling popular pada masa ini, menyediakan pelbagai alatan dan komponen untuk membantu pembangun mencapai kesan reka letak penyesuaian. Artikel ini akan berkongsi beberapa garis panduan dan petua untuk melaksanakan reka bentuk responsif menggunakan React, dan menyediakan contoh kod khusus untuk rujukan. Fle menggunakan React

Cara membina aplikasi pemesejan yang boleh dipercayai dengan React dan RabbitMQ Pengenalan: Aplikasi moden perlu menyokong pemesejan yang boleh dipercayai untuk mencapai ciri seperti kemas kini masa nyata dan penyegerakan data. React ialah perpustakaan JavaScript yang popular untuk membina antara muka pengguna, manakala RabbitMQ ialah perisian tengah pemesejan yang boleh dipercayai. Artikel ini akan memperkenalkan cara menggabungkan React dan RabbitMQ untuk membina aplikasi pemesejan yang boleh dipercayai dan memberikan contoh kod khusus. Gambaran keseluruhan RabbitMQ:

Panduan penyahpepijatan kod tindak balas: Cara mencari dan menyelesaikan pepijat bahagian hadapan dengan cepat Pengenalan: Semasa membangunkan aplikasi React, anda sering menghadapi pelbagai pepijat yang mungkin ranap aplikasi atau menyebabkan tingkah laku yang salah. Oleh itu, menguasai kemahiran penyahpepijatan adalah keupayaan penting untuk setiap pembangun React. Artikel ini akan memperkenalkan beberapa teknik praktikal untuk mencari dan menyelesaikan pepijat bahagian hadapan, dan menyediakan contoh kod khusus untuk membantu pembaca mencari dan menyelesaikan pepijat dengan cepat dalam aplikasi React. 1. Pemilihan alat nyahpepijat: Dalam Re

Panduan Pengguna ReactRouter: Cara Melaksanakan Kawalan Penghalaan Hadapan Dengan populariti aplikasi satu halaman, penghalaan bahagian hadapan telah menjadi bahagian penting yang tidak boleh diabaikan. Sebagai perpustakaan penghalaan paling popular dalam ekosistem React, ReactRouter menyediakan fungsi yang kaya dan API yang mudah digunakan, menjadikan pelaksanaan penghalaan bahagian hadapan sangat mudah dan fleksibel. Artikel ini akan memperkenalkan cara menggunakan ReactRouter dan menyediakan beberapa contoh kod khusus. Untuk memasang ReactRouter dahulu, kita perlukan

Cara menggunakan React dan Google BigQuery untuk membina aplikasi analisis data yang pantas Pengenalan: Dalam era ledakan maklumat hari ini, analisis data telah menjadi pautan yang sangat diperlukan dalam pelbagai industri. Antaranya, membina aplikasi analisis data yang pantas dan cekap telah menjadi matlamat yang diusahakan oleh banyak syarikat dan individu. Artikel ini akan memperkenalkan cara menggunakan React dan Google BigQuery untuk membina aplikasi analisis data yang pantas dan memberikan contoh kod terperinci. 1. Gambaran Keseluruhan React ialah alat untuk membina
