国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

Rumah hujung hadapan web tutorial js Bina nodemon Anda Sendiri dalam Beberapa Baris Kod

Bina nodemon Anda Sendiri dalam Beberapa Baris Kod

Oct 19, 2024 pm 10:32 PM

Build Your Own nodemon in Few Lines of Code

Jadual Kandungan

  1. Pengenalan
  2. Menyediakan Projek
  3. Pelayan
  4. Pemerhati
  5. Menyatukan Kepingan
  6. Rujukan

Anda boleh mencari kod sumber di sini: https://github.com/aelassas/watcher

pengenalan

Apabila bekerja pada aplikasi Node.js, anda selalunya perlu memulakan semula pelayan anda selepas beberapa perubahan. Nah, ini akan menjengkelkan jika anda perlu memulakan semula pelayan anda secara manual setiap kali anda melakukan beberapa pengubahsuaian dalam kod sumber anda. Syukurlah, terdapat beberapa utiliti yang tersedia yang membolehkan anda memulakan semula pelayan anda secara automatik apabila perubahan dikesan. Dan yang paling terkenal ialah nodemon. nodemon ialah alat yang membantu membangunkan aplikasi berasaskan Node.js dengan memulakan semula aplikasi nod secara automatik apabila perubahan fail dalam direktori dikesan. Tujuan petua ini bukan untuk mencipta semula roda, tetapi untuk menunjukkan kepada anda cara anda boleh mencipta utiliti anda sendiri yang memantau sebarang perubahan dalam aplikasi Node.js anda dan memulakan semula pelayan secara automatik dalam beberapa baris kod sahaja.

Menyediakan Projek

Langkah pertama adalah untuk memulakan projek Node.js kami:

npm init

Kemudian, kami perlu mengemas kini package.json untuk menambah sokongan ES6 dengan menetapkan modul sebagai jenis:

{
  "name": "watcher",
  "type": "module",
  "version": "1.0.0",
  "author": "Akram El Assas"
}

Kemudian, kami akan memasang kebergantungan pembangunan:

npm i -D @types/node
  • @types/node: Untuk mempunyai autolengkap dalam Kod Visual Studio

pelayan

Kami akan mencipta pelayan web ringkas server.js seperti berikut:

import { createServer } from 'http'

const PORT = 8888

createServer((_, res) => {
    res.writeHead(200, { 'Content-Type': 'text/plain' })
    res.write('Hello World!')
    res.end()
}).listen(PORT)

console.log('HTTP server is running on Port', PORT)

Kemudian, kami akan mencipta pemerhati untuk memulakan semula pelayan setiap kali perubahan dikesan pada folder induk pelayan dan dalam subfoldernya melalui arahan berikut:

node watcher.js server.js

Pemerhati

Pemerhati akan memulakan semula pelayan setiap kali perubahan dikesan.

Pertama sekali, kita perlu mendapatkan semula argumen baris arahan. Dalam Node.js, kita boleh mempunyai akses kepada argumen baris perintah melalui process.argv. Sifat process.argv mengembalikan tatasusunan yang mengandungi argumen baris perintah yang diluluskan apabila proses Node.js dilancarkan. Elemen pertama ialah execPath. Elemen kedua akan menjadi laluan ke fail JavaScript yang sedang dilaksanakan. Elemen yang selebihnya ialah sebarang argumen baris perintah tambahan.

Jika kita menjalankan arahan berikut:

node watcher.js server.js

process.argv adalah seperti berikut:

[
  'C:\Program Files\nodejs\node.exe',
  'C:\dev\watcher\src\watcher.js',
  'server.js'
]

Elemen pertama ialah laluan ke Node.js boleh laku. Elemen kedua ialah laluan ke watcher.js. Dan elemen terakhir ialah server.js. Oleh itu, kita boleh memulakan kod kita dengan mengisytiharkan elemen pertama dan ketiga seperti berikut:

npm init

Kami kemudiannya perlu mencipta fungsi yang memulakan proses anak yang melancarkan Node.js dengan fail yang ditentukan sebagai argumen yang dalam kes kami ialah server.js. Untuk berbuat demikian, kami akan menggunakan kaedah spawn dari modul child_process. Kaedah child_process.spawn() menghasilkan proses baharu menggunakan arahan yang diberikan, dengan argumen baris perintah dalam args. Kelebihan menggunakan kaedah spawn ialah kita boleh mengalihkan stdout dan stderr proses anak ke proses induk menggunakan kaedah paip. kaedah paip digunakan untuk melampirkan strim boleh tulis pada strim boleh dibaca supaya ia seterusnya bertukar ke mod mengalir dan kemudian menolak semua data yang ada pada aliran boleh tulis yang dilampirkan. Kod sumber fungsi kami akan kelihatan seperti berikut:

{
  "name": "watcher",
  "type": "module",
  "version": "1.0.0",
  "author": "Akram El Assas"
}

Pertama sekali, kami melahirkan proses Node.js anak dengan argumen fail yang diberikan. Kemudian, kami mengubah hala stdout dan stderr proses anak ke proses induk menggunakan kaedah paip. Kemudian, apabila proses anak ditutup, kami keluar dari proses induk dengan kod keluar yang sama. Kaedah process.exit() mengarahkan Node.js untuk menamatkan proses secara serentak dengan status keluar kod. Jika kod ditinggalkan, keluar menggunakan sama ada kod kejayaan 0 atau nilai process.exitCode jika ia telah ditetapkan. Node.js tidak akan ditamatkan sehingga semua pendengar acara keluar dipanggil. Dan akhirnya, kami mengembalikan proses anak.

Kini, kita perlu mengesan perubahan pada folder induk fail dan subfoldernya. Dan setiap kali perubahan yang berkaitan dengan fail JavaScript dikesan, kami akan mematikan proses anak dan melahirkan proses anak semula. Untuk berbuat demikian, kami akan menggunakan kaedah menonton daripada modul fs/promises. Kaedah fs/promises.watch() mengembalikan iterator async yang memerhatikan perubahan pada nama fail, dengan nama fail sama ada fail atau direktori. Kami akan membuat pemerhati pada folder induk fail. Kemudian, kita akan berulang melalui pemerhati. Kami akan mengabaikan folder node_modules dan setiap kali perubahan dikesan pada fail JavaScript, kami akan membunuh proses kanak-kanak dan menghasilkannya semula seperti berikut:

npm i -D @types/node

Kaedah subprocess.kill() menghantar isyarat kepada proses anak. Jika tiada hujah diberikan, proses akan dihantar isyarat SIGTERM. Isyarat SIGKILL tidak boleh ditangkap, disekat atau diabaikan dan memaksa proses kanak-kanak berhenti. Lihat isyarat(7) untuk senarai isyarat yang tersedia.

Itu sahaja! Kami telah menyelesaikan nodemon kami sendiri hanya dalam beberapa baris kod.

Akhir sekali, kita perlu menambah skrip permulaan dan dev pada package.json kami seperti berikut:

import { createServer } from 'http'

const PORT = 8888

createServer((_, res) => {
    res.writeHead(200, { 'Content-Type': 'text/plain' })
    res.write('Hello World!')
    res.end()
}).listen(PORT)

console.log('HTTP server is running on Port', PORT)

Untuk memulakan aplikasi kami, hanya taip arahan berikut:

node watcher.js server.js

Sekarang jika kami menjalankan aplikasi kami dan membuat perubahan pada server.js, pelayan akan dimulakan semula secara automatik. Kami tidak perlu lagi berhenti dan memulakan pelayan secara manual.

Membawa Potongan Bersama

Kami menyediakan nodemon kami sendiri hanya dalam beberapa baris kod. Kini, keseluruhan kod sumber watcher.js kami kelihatan seperti berikut:

npm init

Ini hanyalah contoh mudah tetapi anda boleh bayangkan situasi lain di mana anda memantau perubahan pada fail video dan setiap kali perubahan dikesan, proses anak penukaran (ffmpeg) dilancarkan.

Anda juga boleh melaksanakan pilihan lain seperti:

  • Mengabaikan fail atau direktori tertentu
  • Menonton direktori tertentu
  • Memantau berbilang direktori
  • Menentukan senarai tontonan sambungan
  • Menangguhkan memulakan semula
  • Menjalankan boleh laku selain Node.js seperti Python, Ruby, make, dll.
  • dan seterusnya...

Rujukan

  • nodemon
  • child_process.spawn(command[, args][, options])
  • process.exit([kod])
  • fsPromises.watch(nama fail[, pilihan])
  • process.kill(pid[, isyarat])
  • isyarat(7)

Atas ialah kandungan terperinci Bina nodemon Anda Sendiri dalam Beberapa Baris Kod. 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.

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

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)

Java vs JavaScript: Membersihkan kekeliruan Java vs JavaScript: Membersihkan kekeliruan Jun 20, 2025 am 12:27 AM

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza, masing -masing sesuai untuk senario aplikasi yang berbeza. Java digunakan untuk pembangunan aplikasi perusahaan dan mudah alih yang besar, sementara JavaScript digunakan terutamanya untuk pembangunan laman web.

Komen JavaScript: Penjelasan ringkas Komen JavaScript: Penjelasan ringkas Jun 19, 2025 am 12:40 AM

JavaScriptcommentsareessentialformaintaining,reading,andguidingcodeexecution.1)Single-linecommentsareusedforquickexplanations.2)Multi-linecommentsexplaincomplexlogicorprovidedetaileddocumentation.3)Inlinecommentsclarifyspecificpartsofcode.Bestpractic

Bagaimana untuk bekerja dengan tarikh dan masa di JS? Bagaimana untuk bekerja dengan tarikh dan masa di JS? Jul 01, 2025 am 01:27 AM

Titik berikut harus diperhatikan apabila tarikh pemprosesan dan masa di JavaScript: 1. Terdapat banyak cara untuk membuat objek tarikh. Adalah disyorkan untuk menggunakan rentetan format ISO untuk memastikan keserasian; 2. Dapatkan dan tetapkan maklumat masa boleh diperoleh dan tetapkan kaedah, dan ambil perhatian bahawa bulan bermula dari 0; 3. Tarikh pemformatan secara manual memerlukan rentetan, dan perpustakaan pihak ketiga juga boleh digunakan; 4. Adalah disyorkan untuk menggunakan perpustakaan yang menyokong zon masa, seperti Luxon. Menguasai perkara -perkara utama ini secara berkesan dapat mengelakkan kesilapan yang sama.

Kenapa anda harus meletakkan tag  di bahagian bawah ? Kenapa anda harus meletakkan tag di bahagian bawah ? Jul 02, 2025 am 01:22 AM

PlacingtagsatthebottomofablogpostorwebpageservespracticalpurposesforSEO,userexperience,anddesign.1.IthelpswithSEObyallowingsearchenginestoaccesskeyword-relevanttagswithoutclutteringthemaincontent.2.Itimprovesuserexperiencebykeepingthefocusonthearticl

JavaScript vs Java: Perbandingan Komprehensif untuk Pemaju JavaScript vs Java: Perbandingan Komprehensif untuk Pemaju Jun 20, 2025 am 12:21 AM

JavaScriptispreferredforwebdevelopment, whersjavaisbetterforlarge-scalebackendsystemsandandroidapps.1) javascriptexcelsinceleatinginteractiveWebexperienceswithitsdynamicnatureanddommanipulation.2) javaoffersstrongyblectionandobjection

JavaScript: Meneroka jenis data untuk pengekodan yang cekap JavaScript: Meneroka jenis data untuk pengekodan yang cekap Jun 20, 2025 am 12:46 AM

JavascripthassevenfundamentalDatypes: nombor, rentetan, boolean, undefined, null, objek, andsymbol.1) numberuseadouble-precisionformat, bergunaforwidevaluangesbutbecautiouswithfloating-pointarithmetic.2)

Apakah peristiwa yang menggelegak dan menangkap di Dom? Apakah peristiwa yang menggelegak dan menangkap di Dom? Jul 02, 2025 am 01:19 AM

Penangkapan dan gelembung acara adalah dua peringkat penyebaran acara di Dom. Tangkap adalah dari lapisan atas ke elemen sasaran, dan gelembung adalah dari elemen sasaran ke lapisan atas. 1. Penangkapan acara dilaksanakan dengan menetapkan parameter useCapture addeventlistener kepada benar; 2. Bubble acara adalah tingkah laku lalai, useCapture ditetapkan kepada palsu atau ditinggalkan; 3. Penyebaran acara boleh digunakan untuk mencegah penyebaran acara; 4. Acara menggelegak menyokong delegasi acara untuk meningkatkan kecekapan pemprosesan kandungan dinamik; 5. Penangkapan boleh digunakan untuk memintas peristiwa terlebih dahulu, seperti pemprosesan pembalakan atau ralat. Memahami kedua -dua fasa ini membantu mengawal masa dan bagaimana JavaScript bertindak balas terhadap operasi pengguna.

Apa perbezaan antara Java dan JavaScript? Apa perbezaan antara Java dan JavaScript? Jun 17, 2025 am 09:17 AM

Java dan JavaScript adalah bahasa pengaturcaraan yang berbeza. 1.Java adalah bahasa yang ditaip dan disusun secara statik, sesuai untuk aplikasi perusahaan dan sistem besar. 2. JavaScript adalah jenis dinamik dan bahasa yang ditafsirkan, terutamanya digunakan untuk interaksi web dan pembangunan front-end.

See all articles