Node.js belajar dan bersembang tentang modul Acara
Artikel ini akan membawa anda melalui modul Acara dalam Node.js dan memperkenalkan model terbitan dan langganan dalam Acara saya harap ia akan membantu anda!
Modul acara
Rujukan tapak web rasmi: pencetus acara acara | Node.js
http ://nodejs.cn/api/events.html
Events
modul ialah modul terpenting Node Ia menyediakan atribut EventEmitter
teras EventEmitter
ialah pelepasan peristiwa dan Pendengar acara. Kebanyakan modul dalam
Nod mewarisi daripada modul Events
. Modul
-
Events
ialah pelaksanaan Node bagi corak publish-subscribe (publish/subscribe
). Satu objek menghantar mesej ke objek lain melalui modul ini. - Modul ini menyediakan pembina melalui atribut
EventEmitter
. Contoh pembina ini mempunyaion
kaedah yang boleh digunakan untuk mendengar acara tertentu dan mencetuskan fungsi panggil balik. - Sebarang objek boleh menerbitkan acara tertentu, yang dipantau oleh kaedah on contoh
EventEmitter
.
Model Terbit-Langgan
Mengenai Model Terbit-Langgan, anda boleh rujuk artikel blog saya sebelum ini.
Berkenaan model terbitkan-langganan dalam Events
, kita perlu terlebih dahulu memahami beberapa kaedah lazimnya.
-
Kaedah langganan : Kaedah
on
digunakan untuk melanggan kaedah peta Langganan ke dalam perhubungan satu dengan banyak. -
Kaedah terbitan :
emit
digunakan untuk melaksanakan acara yang dilanggan. -
Nyahlanggan: Kaedah
off
boleh mengalih keluar pendengar acara yang sepadan. -
Langgan sekali :
once
Acara terikat akan memadamkan acara yang dilanggan secara automatik selepas pelaksanaan. Parameter pertama kaedah
dihidupkan dan dipancarkan
on
digunakan untuk menetapkan nama kelas, dan parameter kedua juga merupakan fungsi, yang boleh Menerima parameter yang dihantar semasa menerbitkan. Parameter pertama kaedah
emit
ialah nama kelas, dan parameter seterusnya ialah parameter yang dihantar ke dalam fungsi kaedah on
.
on
dan emit
boleh merujuk kepada Demo mudah di bawah untuk aplikasi tertentu.
const EventEmitter = require('events'); // 自定义一个 构造函数 function Cat() {} // 原型继承 需要通过实例来调用继承方法 Object.setPrototypeOf(Cat.prototype, EventEmitter.prototype); let cat = new Cat(); const sleep = (a, b) => { console.log(a, '睡'); }; const eat = (a, b) => { console.log(b, '吃'); }; cat.on('猫咪', sleep) cat.on('猫咪', eat) setTimeout(() => { // 小胡子 吃 // 小胖仙 睡 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
Kini kita boleh melaksanakan satu set kaedah on
dan emit
.
function EventEmitter() { this._event = {} } // on 方法 EventEmitter.prototype.on = function (eventName, callBack) { if (!this._event) { this._event = {} } if (this._event[eventName]) { this._event[eventName].push(callBack) // 相当于 {eventName:[fn1,fn2]} } else { this._event[eventName] = [callBack]; // 相当于 {eventName:[fn1]} } } // emit 方法 EventEmitter.prototype.emit = function (eventName, ...args) { this._event[eventName].forEach(fn => { fn(...args) }); }
mati
off
Parameter pertama kaedah digunakan untuk menetapkan nama kelas, dan parameter kedua diluluskan dalam fungsi yang memerlukan untuk dialih keluar panggilan balik.
// ... setTimeout(() => { // 小胡子 吃 // 小胖仙 睡 cat.emit('猫咪', '小胖仙', '小胡子') cat.off('猫咪', sleep); // 小胡子 吃 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
Dengan cara ini kita boleh menilai secara kasar dan mengalih keluar fungsi yang sama seperti fungsi yang kita lalui. Kami dengan pantas memikirkan kaedah penapis.
// off 方法 EventEmitter.prototype.off = function (eventName, callBack) { if (this._event && this._event[eventName]) { this._event[eventName] = this._event[eventName].filter( fn => fn !== callBack && fn.c !== callBack // fn.c参考下面的once方法实现 ) } }
sekali
once
Parameter pertama kaedah digunakan untuk menetapkan nama kelas, dan parameter kedua diluluskan dalam fungsi yang hanya perlu dilaksanakan sekali panggil balik.
// ... const demolition =() => { console.log('拆家'); } cat.once('猫咪', demolition) setTimeout(() => { // ...... 拆家 cat.emit('猫咪', '小胖仙', '小胡子') }, 1000);
Dengan cara ini kita boleh melaksanakan kaedah ini berdasarkan on
dan off
yang telah dilaksanakan sebelum ini.
// once 方法 EventEmitter.prototype.once = function (eventName, callBack) { const one = () => { callBack(); this.off(eventName, one); } this.on(eventName, one); }
Nampaknya tiada yang salah dengan kaedah ini, dan semuanya dilaksanakan dengan betul.
Tetapi dalam kes khas, ralat masih berlaku.
Situasi itu adalah jika kita telah mengeluarkannya melalui kaedah once
sebelum melaksanakan kaedah off
.
Kaedah yang kami laksanakan tidak dapat memenuhi keperluan ini, jadi kami masih perlu membuat beberapa pengubahsuaian pada once
kaedah (kaedah off
telah pun diproses) .
Tambahkan atribut tersuai pada "cache" fungsi.
EventEmitter.prototype.once = function (eventName, callBack) { const one = () => { // ... } one.c = callBack; // 自定义一个属性 // ... }
Dengan cara ini kami melaksanakan kaedah once
.
Untuk lebih banyak pengetahuan berkaitan nod, sila lawati: tutorial nodejs! !
Atas ialah kandungan terperinci Node.js belajar dan bersembang tentang modul Acara. 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

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

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











Artikel ini akan memberi anda pemahaman yang mendalam tentang memori dan pengumpul sampah (GC) enjin NodeJS V8 saya harap ia akan membantu anda!

Perkhidmatan Node yang dibina berdasarkan bukan sekatan dan dipacu peristiwa mempunyai kelebihan penggunaan memori yang rendah dan sangat sesuai untuk mengendalikan permintaan rangkaian besar-besaran. Di bawah premis permintaan besar-besaran, isu yang berkaitan dengan "kawalan memori" perlu dipertimbangkan. 1. Mekanisme kutipan sampah V8 dan had ingatan Js dikawal oleh mesin kutipan sampah

Memilih imej Docker untuk Node mungkin kelihatan seperti perkara remeh, tetapi saiz dan potensi kelemahan imej itu boleh memberi kesan yang ketara pada proses dan keselamatan CI/CD anda. Jadi bagaimana kita memilih imej Node.js Docker yang terbaik?

Node 19 telah dikeluarkan secara rasmi Artikel ini akan memberi anda penjelasan terperinci tentang 6 ciri utama Node.js 19. Saya harap ia akan membantu anda!

Bagaimana untuk membungkus fail boleh laku nodejs dengan pkg? Artikel berikut akan memperkenalkan kepada anda cara menggunakan pkg untuk membungkus projek Node ke dalam fail boleh laku. Saya harap ia akan membantu anda!

Modul fail ialah enkapsulasi operasi fail asas, seperti membaca/menulis/membuka/menutup/memadam fail, dsb. Ciri terbesar modul fail ialah semua kaedah menyediakan dua versi **segerak** dan ** asynchronous**, dengan Kaedah dengan akhiran penyegerakan adalah semua kaedah penyegerakan, dan kaedah yang tidak semuanya adalah kaedah heterogen.

Gelung peristiwa ialah bahagian asas Node.js dan mendayakan pengaturcaraan tak segerak dengan memastikan bahawa utas utama tidak disekat Memahami gelung peristiwa adalah penting untuk membina aplikasi yang cekap. Artikel berikut akan memberi anda pemahaman yang mendalam tentang gelung acara dalam Node.

Sebab mengapa nod tidak boleh menggunakan arahan npm adalah kerana pembolehubah persekitaran tidak dikonfigurasikan dengan betul Penyelesaiannya ialah: 1. Buka "Sistem Sifat"; 2. Cari "Pembolehubah Persekitaran" -> "Pembolehubah Sistem", dan kemudian edit persekitaran. pembolehubah; 3. Cari lokasi folder nodejs;
