cari
Rumahhujung hadapan webtutorial jsNode.js: Sejarah ringkas cjs, bundlers dan esm

Node.js: A brief history of cjs, bundlers, and esm

pengenalan

Jika anda seorang pembangun Node.js, anda mungkin pernah mendengar tentang modul cjs dan esm tetapi mungkin tidak pasti mengapa terdapat dua dan bagaimana ini wujud bersama dalam aplikasi Node.js. Catatan blog ini akan membimbing anda secara ringkas mengenai sejarah modul JavaScript dalam Node.js (dengan contoh ?) supaya anda boleh berasa lebih yakin apabila berurusan dengan konsep ini.

Skop global

Pada mulanya JavaScript hanya mempunyai skop global apabila semua ahli diisytiharkan. Ini bermasalah semasa berkongsi kod kerana dua fail bebas mungkin menggunakan nama yang sama untuk ahli. Contohnya:

salam-1.js

function greet(name) {
  return `Hello ${name}!`;
}

salam-2.js

var greet = "...";

index.html


  
    <meta charset="utf-8">
    <title>Collision example</title>
  
  
    <!-- After this script, `greet` is a function -->
    <script src="greet-1.js"></script>

    <!-- After this script, `greet` is a string -->
    <script src="greet-2.js"></script>

    <script>
        // TypeError: "greet" is not a function
        greet();
    </script>
  

Modul CommonJS

Node.js secara rasmi memperkenalkan konsep modul JavaScript dengan CommonJS (juga dikenali sebagai cjs). Ini menyelesaikan masalah perlanggaran skop global yang dikongsi kerana pembangun boleh memutuskan perkara yang hendak dieksport (melalui module.exports) dan import (melalui require()). Contohnya:

src/greet.js

// this remains "private"
const GREETING_PREFIX = "Hello";

// this will be exported
function greet(name) {
  return `${GREETING_PREFIX} ${name}!`;
}

// `exports` is a shortcut to `module.exports`
exports.greet = greet;

src/main.js

// notice the `.js` suffix is missing
const { greet } = require("./greet");

// logs: Hello Alice!
console.log(greet("Alice"));

pakej npm

Pembangunan Node.js meledak dalam populariti berkat pakej npm yang membenarkan pembangun menerbitkan dan menggunakan kod JavaScript yang boleh digunakan semula. pakej npm dipasang dalam folder node_modules secara lalai. Fail package.json yang terdapat dalam semua pakej npm adalah sangat penting kerana ia boleh menunjukkan Node.js fail mana yang menjadi titik masuk melalui sifat "utama". Contohnya:

node_modules/greeter/package.json

{
  "name": "greeter",
  "main": "./entry-point.js"
  // ...
}

node_modules/greeter/entry-point.js

module.exports = {
  greet(name) {
    return `Hello ${name}!`;
  }
};

src/main.js

// notice there's no relative path (e.g. `./`)
const { greet } = require("greeter");

// logs: Hello Bob!
console.log(greet("Bob"));

Pengikat

Pakej npm secara mendadak mempercepatkan produktiviti pembangun dengan dapat memanfaatkan kerja pembangun lain. Walau bagaimanapun, ia mempunyai kelemahan utama: cjs tidak serasi dengan pelayar web. Untuk menyelesaikan masalah ini, konsep pengikat telah dilahirkan. browserify ialah pengikat pertama yang pada asasnya berfungsi dengan merentasi titik masuk dan "menggabungkan" semua kod require()-ed ke dalam satu fail .js yang serasi dengan pelayar web. Apabila masa berlalu, pengikat lain dengan ciri tambahan dan pembeza telah diperkenalkan. Terutamanya webpack, parcel, rollup, esbuild dan vite (dalam susunan kronologi).

Modul ECMAScript

Memandangkan modul Node.js dan cjs menjadi arus perdana, penyelenggara spesifikasi ECMAScript memutuskan untuk memasukkan konsep modul. Inilah sebabnya mengapa modul JavaScript asli juga dikenali sebagai ESModules atau esm (singkatan daripada modul ECMAScript).

esm mentakrifkan kata kunci dan sintaks baharu untuk mengeksport dan mengimport ahli serta memperkenalkan konsep baharu seperti eksport lalai. Dari masa ke masa, modul esm memperoleh keupayaan baharu seperti import dinamik() dan menunggu peringkat tertinggi. Contohnya:

src/greet.js

function greet(name) {
  return `Hello ${name}!`;
}

src/part.js

var greet = "...";

src/main.js


  
    <meta charset="utf-8">
    <title>Collision example</title>
  
  
    <!-- After this script, `greet` is a function -->
    <script src="greet-1.js"></script>

    <!-- After this script, `greet` is a string -->
    <script src="greet-2.js"></script>

    <script>
        // TypeError: "greet" is not a function
        greet();
    </script>
  

Lama kelamaan, esm mula diterima pakai secara meluas oleh pembangun terima kasih kepada pengikat dan bahasa seperti TypeScript kerana ia mampu mengubah sintaks esm menjadi cjs.

Node.js cjs/esm kebolehoperasian

Disebabkan permintaan yang semakin meningkat, Node.js secara rasmi menambah sokongan untuk esm dalam versi 12.x. Keserasian ke belakang dengan cjs dicapai seperti berikut:

  • Node.js mentafsir fail .js sebagai modul cjs melainkan package.json menetapkan sifat "jenis" kepada "modul".
  • Node.js mentafsir fail .cjs sebagai modul cjs.
  • Node.js mentafsir fail .mjs sebagai modul esm.

Mengenai keserasian pakej npm, modul esm boleh mengimport pakej npm dengan titik masuk cjs dan esm. Walau bagaimanapun, sebaliknya datang dengan beberapa kaveat. Ambil contoh berikut:

node_modules/cjs/package.json

// this remains "private"
const GREETING_PREFIX = "Hello";

// this will be exported
function greet(name) {
  return `${GREETING_PREFIX} ${name}!`;
}

// `exports` is a shortcut to `module.exports`
exports.greet = greet;

node_modules/cjs/entry.js

// notice the `.js` suffix is missing
const { greet } = require("./greet");

// logs: Hello Alice!
console.log(greet("Alice"));

node_modules/esm/package.json

{
  "name": "greeter",
  "main": "./entry-point.js"
  // ...
}

node_modules/esm/entry.js

module.exports = {
  greet(name) {
    return `Hello ${name}!`;
  }
};

Perkara berikut berjalan lancar:

src/main.mjs

// notice there's no relative path (e.g. `./`)
const { greet } = require("greeter");

// logs: Hello Bob!
console.log(greet("Bob"));

Walau bagaimanapun, perkara berikut gagal dijalankan:

src/main.cjs

// this remains "private"
const GREETING_PREFIX = "Hello";

// this will be exported
export function greet(name) {
  return `${GREETING_PREFIX} ${name}!`;
}

Sebab mengapa ini tidak dibenarkan adalah kerana modul esm membenarkan menunggu peringkat teratas manakala fungsi require() adalah segerak. Kod itu boleh ditulis semula untuk menggunakan import dinamik(), tetapi kerana ia mengembalikan Promise, ia memaksa untuk mempunyai sesuatu seperti berikut:

src/main.cjs

// default export: new concept
export default function part(name) {
  return `Goodbye ${name}!`;
}

Untuk mengurangkan masalah keserasian ini, sesetengah pakej npm mendedahkan kedua-dua titik masuk cjs dan mjs dengan memanfaatkan sifat "eksport" package.json dengan eksport bersyarat. Contohnya:

node_modules/esm/entry.cjs:

// notice the `.js` suffix is required
import part from "./part.js";

// dynamic import: new capability
// top-level await: new capability
const { greet } = await import("./greet.js");

// logs: Hello Alice!
console.log(greet("Alice"));

// logs: Bye Bob!
console.log(part("Bob"));

node_modules/esm/package.json:

{
  "name": "cjs",
  "main": "./entry.js"
}

Perhatikan cara "utama" menunjuk ke versi cjs untuk keserasian ke belakang dengan versi Node.js yang tidak menyokong sifat "eksport".

Kesimpulan

Itu sahaja (hampir) yang anda perlu tahu tentang modul cjs dan esm (sehingga Dis/2024 ?). Beritahu saya pendapat anda di bawah!

Atas ialah kandungan terperinci Node.js: Sejarah ringkas cjs, bundlers dan esm. 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
Ganti aksara rentetan dalam javascriptGanti aksara rentetan dalam javascriptMar 11, 2025 am 12:07 AM

Penjelasan terperinci mengenai kaedah penggantian rentetan javascript dan Soalan Lazim Artikel ini akan meneroka dua cara untuk menggantikan watak rentetan dalam JavaScript: Kod JavaScript dalaman dan HTML dalaman untuk laman web. Ganti rentetan di dalam kod JavaScript Cara yang paling langsung ialah menggunakan kaedah pengganti (): str = str.replace ("cari", "ganti"); Kaedah ini hanya menggantikan perlawanan pertama. Untuk menggantikan semua perlawanan, gunakan ungkapan biasa dan tambahkan bendera global g: str = str.replace (/fi

Tutorial Persediaan API Carian Google CustomTutorial Persediaan API Carian Google CustomMar 04, 2025 am 01:06 AM

Tutorial ini menunjukkan kepada anda bagaimana untuk mengintegrasikan API carian Google tersuai ke dalam blog atau laman web anda, menawarkan pengalaman carian yang lebih halus daripada fungsi carian tema WordPress standard. Ia menghairankan mudah! Anda akan dapat menyekat carian ke y

Bina Aplikasi Web Ajax anda sendiriBina Aplikasi Web Ajax anda sendiriMar 09, 2025 am 12:11 AM

Jadi di sini anda, bersedia untuk mempelajari semua perkara ini yang dipanggil Ajax. Tetapi, apa sebenarnya? Istilah Ajax merujuk kepada kumpulan teknologi longgar yang digunakan untuk membuat kandungan web yang dinamik dan interaktif. Istilah Ajax, yang asalnya dicipta oleh Jesse J

Contoh warna json failContoh warna json failMar 03, 2025 am 12:35 AM

Siri artikel ini ditulis semula pada pertengahan 2017 dengan maklumat terkini dan contoh segar. Dalam contoh JSON ini, kita akan melihat bagaimana kita dapat menyimpan nilai mudah dalam fail menggunakan format JSON. Menggunakan notasi pasangan nilai utama, kami boleh menyimpan apa-apa jenis

10 JQuery Syntax Highlighters10 JQuery Syntax HighlightersMar 02, 2025 am 12:32 AM

Tingkatkan Penyampaian Kod Anda: 10 Penyeret Sintaks untuk Pemaju Coretan kod perkongsian di laman web atau blog anda adalah amalan biasa bagi pemaju. Memilih penyapu sintaks yang betul dapat meningkatkan daya tarikan dan daya tarikan visual dengan ketara. T

8 plugin susun atur halaman jquery yang menakjubkan8 plugin susun atur halaman jquery yang menakjubkanMar 06, 2025 am 12:48 AM

Leverage JQuery untuk Layouts Laman Web yang mudah: 8 Plugin Essential JQuery memudahkan susun atur laman web dengan ketara. Artikel ini menyoroti lapan plugin jQuery yang kuat yang menyelaraskan proses, terutamanya berguna untuk penciptaan laman web manual

10 JavaScript & JQuery MVC Tutorial10 JavaScript & JQuery MVC TutorialMar 02, 2025 am 01:16 AM

Artikel ini membentangkan pemilihan lebih daripada 10 tutorial mengenai rangka kerja javascript dan jquery model-view-controller (MVC), sesuai untuk meningkatkan kemahiran pembangunan web anda pada tahun baru. Tutorial ini merangkumi pelbagai topik, dari Foundatio

Apa itu ' ini ' Dalam JavaScript?Apa itu ' ini ' Dalam JavaScript?Mar 04, 2025 am 01:15 AM

Mata teras Ini dalam JavaScript biasanya merujuk kepada objek yang "memiliki" kaedah, tetapi ia bergantung kepada bagaimana fungsi dipanggil. Apabila tidak ada objek semasa, ini merujuk kepada objek global. Dalam penyemak imbas web, ia diwakili oleh tetingkap. Apabila memanggil fungsi, ini mengekalkan objek global; tetapi apabila memanggil pembina objek atau mana -mana kaedahnya, ini merujuk kepada contoh objek. Anda boleh mengubah konteks ini menggunakan kaedah seperti panggilan (), memohon (), dan mengikat (). Kaedah ini memanggil fungsi menggunakan nilai dan parameter yang diberikan. JavaScript adalah bahasa pengaturcaraan yang sangat baik. Beberapa tahun yang lalu, ayat ini

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Alat panas

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

DVWA

DVWA

Damn Vulnerable Web App (DVWA) ialah aplikasi web PHP/MySQL yang sangat terdedah. Matlamat utamanya adalah untuk menjadi bantuan bagi profesional keselamatan untuk menguji kemahiran dan alatan mereka dalam persekitaran undang-undang, untuk membantu pembangun web lebih memahami proses mengamankan aplikasi web, dan untuk membantu guru/pelajar mengajar/belajar dalam persekitaran bilik darjah Aplikasi web keselamatan. Matlamat DVWA adalah untuk mempraktikkan beberapa kelemahan web yang paling biasa melalui antara muka yang mudah dan mudah, dengan pelbagai tahap kesukaran. Sila ambil perhatian bahawa perisian ini

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Dreamweaver Mac版

Dreamweaver Mac版

Alat pembangunan web visual