JavaScript terus berkembang, sentiasa memperkenalkan ciri dan sintaks baharu untuk meningkatkan prestasi dan ekspresi bahasa. Salah satu penambahbaikan yang paling menarik ialah pengendali penggabungan nol (??). Operator ini ialah pengubah permainan, menyediakan cara yang ringkas dan intuitif untuk bekerja dengan nilai null
dan undefined
. Artikel ini akan melihat secara mendalam pengendali penggabungan nol, menganalisis kelebihannya dan menerangkan cara menggunakannya dengan berkesan dalam TypeScript.
Pengenalan kepada pengendali penyatuan nilai nol
Operator penggabungan nol (??) ialah operator logik yang mengembalikan operan kanan apabila operan kiri ialah null
atau undefined
. Ini amat berguna dalam menyediakan nilai lalai dan mengelakkan perangkap biasa yang dikaitkan dengan pengendali OR logik (||).
Masalah dengan operator logik ATAU (||)
Sebelum pengenalan pengendali penggabungan nol, pembangun sering menggunakan operator OR logik (||) untuk memberikan nilai lalai. Walau bagaimanapun, pendekatan ini mempunyai kelemahan yang ketara: ia menyamakan nilai khayalan (seperti 0, '', dan palsu) kepada null
atau undefined
.
let value = 0; let defaultValue = value || 10; console.log(defaultValue); // 输出:10
Dalam contoh di atas, value
ialah 0, yang merupakan nilai khayalan. Oleh itu, defaultValue
diberikan nilai 10, walaupun 0 ialah nombor yang sah. Tingkah laku ini boleh membawa kepada hasil yang tidak dijangka dan ralat dalam kod anda.
Penyelesaian pengendali penggabungan nol (??)
Pengendali penggabungan null (??) menyelesaikan masalah ini dengan mengembalikan operan kanan hanya jika operan kiri ialah null
atau undefined
. Ini menjadikannya pilihan yang lebih dipercayai untuk menyediakan nilai lalai.
let value: number | null | undefined = 0; let defaultValue = value ?? 10; console.log(defaultValue); // 输出:0
Dalam contoh ini, value
ialah 0, yang bukan nol. Oleh itu, defaultValue
diberikan nilai 0, mengekalkan nilai yang dijangkakan.
Kelebihan pengendali penggabungan nilai nol
-
Niat Kosong: Operator penggabungan nol dengan jelas menyampaikan niat untuk memberikan nilai lalai hanya apabila nilai asal ialah
null
atauundefined
. - Elak Ralat: Dengan membezakan antara nilai khayalan dan nilai nol, pengendali penggabungan nol membantu mengelakkan ralat biasa dan tingkah laku yang tidak dijangka.
- Keringkasan: Operator penggabungan nol menyediakan cara ringkas dan boleh dibaca untuk mengendalikan nilai lalai, mengurangkan keperluan untuk pernyataan bersyarat yang panjang.
Menggunakan operator penggabungan nol dalam TypeScript
TypeScript menyokong sepenuhnya pengendali penggabungan null, menjadikannya mudah untuk disepadukan ke dalam projek TypeScript anda. Mari lihat beberapa contoh untuk melihat bagaimana ia boleh digunakan dengan berkesan.
Contoh: Berikan nilai lalai
Salah satu kes penggunaan yang paling biasa untuk operator penggabungan nol ialah menyediakan nilai lalai untuk parameter fungsi.
function greet(name: string | null | undefined, greeting: string = 'Hello'): string { const defaultName = name ?? 'Guest'; return `${greeting}, ${defaultName}!`; } console.log(greet(null)); // 输出:Hello, Guest! console.log(greet(undefined)); // 输出:Hello, Guest! console.log(greet('Alice')); // 输出:Hello, Alice!
Dalam contoh ini, fungsi greet
menggunakan operator penggabungan nol untuk memberikan nama lalai 'Tetamu' apabila argumen name
sama ada null
atau undefined
.
Contoh: Mengendalikan atribut pilihan
Pengendali penggabungan nol juga boleh digunakan untuk mengendalikan sifat pilihan dalam objek.
let value = 0; let defaultValue = value || 10; console.log(defaultValue); // 输出:10
Dalam contoh ini, antara muka User
mempunyai atribut name
dan email
pilihan. Operator penggabungan nol digunakan untuk memberikan nilai lalai apabila sifat ini adalah null
atau undefined
.
Contoh: Menggunakan tatasusunan
Pengendali penggabungan nol juga boleh digunakan untuk mengendalikan nilai nol dalam tatasusunan.
let value: number | null | undefined = 0; let defaultValue = value ?? 10; console.log(defaultValue); // 输出:0
Dalam contoh ini, tatasusunan values
mengandungi nombor, null
dan undefined
. Operator penggabungan nol menggantikan nilai nol dengan 0.
Kes Penggunaan Terperinci
Pengendali penggabungan nol bukan hanya untuk nilai lalai yang mudah. Ia juga boleh digunakan dalam senario yang lebih maju, seperti merantai berbilang nilai sandaran dan menggabungkan dengan pengendali lain.
Contoh: merantai berbilang nilai sandaran
Anda boleh merantai berbilang operator penggabungan nol untuk memberikan berbilang nilai sandaran.
function greet(name: string | null | undefined, greeting: string = 'Hello'): string { const defaultName = name ?? 'Guest'; return `${greeting}, ${defaultName}!`; } console.log(greet(null)); // 输出:Hello, Guest! console.log(greet(undefined)); // 输出:Hello, Guest! console.log(greet('Alice')); // 输出:Hello, Alice!
Dalam contoh ini, value
dan fallback1
adalah batal, jadi pengendali penggabungan nol jatuh kembali kepada fallback2
, yang mempunyai nilai 42.
Contoh: Menggabungkan dengan pengendali lain
Pengendali penggabungan nol boleh digabungkan dengan pengendali lain, seperti pengendali ternary, untuk mencipta ungkapan bersyarat yang lebih kompleks.
interface User { id: number; name?: string; email?: string; } const user: User = { id: 1, name: null, }; const displayName = user.name ?? 'Anonymous'; const displayEmail = user.email ?? 'No email provided'; console.log(`User ID: ${user.id}`); console.log(`Display Name: ${displayName}`); console.log(`Display Email: ${displayEmail}`);
Dalam contoh ini, pengendali ternary digunakan untuk menyemak sama ada value
bukan null
. Jika bukan null
, operator penggabungan nol digunakan untuk memberikan nilai lalai 10. Jika value
ialah null
, hasilnya ialah 20.
Amalan Terbaik
Apabila menggunakan operator penggabungan nol, pastikan anda mengikuti amalan terbaik untuk memastikan kod anda jelas, boleh diselenggara dan bebas ralat.
- Gunakan dengan berhati-hati: Walaupun pengendali penggabungan nol berkuasa, ia harus digunakan dengan berhati-hati. Menggunakannya secara berlebihan boleh menyebabkan kod anda sukar dibaca dan difahami.
- Dokumenkan niat anda: Apabila menggunakan pengendali penggabungan nol, pertimbangkan untuk menambah ulasan untuk mendokumenkan niat anda, terutamanya dalam ungkapan kompleks.
- Elakkan bercampur dengan logik ATAU : Mencampurkan operator penyatuan nol dengan operator OR logik boleh menyebabkan kekeliruan dan ralat. Berpegang kepada pengendali untuk memberikan nilai lalai.
- Uji dengan teliti: Sentiasa uji kod anda dengan teliti untuk memastikan operator penggabungan nol berfungsi seperti yang diharapkan, terutamanya dalam kes sudut.
Kesimpulan
Pengendali penggabungan nol (??) ialah ciri mengubah permainan untuk pembangun JavaScript dan TypeScript. Ia menyediakan cara yang ringkas dan intuitif untuk mengendalikan nilai null
dan undefined
, mengelakkan perangkap biasa yang dikaitkan dengan operator OR logik. Dengan menggunakan operator penggabungan nol, anda boleh menulis kod yang lebih jelas, lebih boleh diselenggara dan kurang terdedah kepada ralat.
Sama ada anda menyediakan nilai lalai, mengendalikan sifat pilihan atau menggunakan tatasusunan, pengendali penggabungan nol telah melindungi anda. Sepadukannya ke dalam projek TypeScript anda hari ini dan rasai manfaatnya secara langsung.
Selamat pengekodan!
Atas ialah kandungan terperinci Operator JavaScript Baharu ini ialah Pengubah Permainan Mutlak. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Trend terkini dalam JavaScript termasuk kebangkitan TypeScript, populariti kerangka dan perpustakaan moden, dan penerapan webassembly. Prospek masa depan meliputi sistem jenis yang lebih berkuasa, pembangunan JavaScript, pengembangan kecerdasan buatan dan pembelajaran mesin, dan potensi pengkomputeran IoT dan kelebihan.

JavaScript adalah asas kepada pembangunan web moden, dan fungsi utamanya termasuk pengaturcaraan yang didorong oleh peristiwa, penjanaan kandungan dinamik dan pengaturcaraan tak segerak. 1) Pengaturcaraan yang didorong oleh peristiwa membolehkan laman web berubah secara dinamik mengikut operasi pengguna. 2) Penjanaan kandungan dinamik membolehkan kandungan halaman diselaraskan mengikut syarat. 3) Pengaturcaraan Asynchronous memastikan bahawa antara muka pengguna tidak disekat. JavaScript digunakan secara meluas dalam interaksi web, aplikasi satu halaman dan pembangunan sisi pelayan, sangat meningkatkan fleksibiliti pengalaman pengguna dan pembangunan silang platform.

Python lebih sesuai untuk sains data dan pembelajaran mesin, manakala JavaScript lebih sesuai untuk pembangunan front-end dan penuh. 1. Python terkenal dengan sintaks ringkas dan ekosistem perpustakaan yang kaya, dan sesuai untuk analisis data dan pembangunan web. 2. JavaScript adalah teras pembangunan front-end. Node.js menyokong pengaturcaraan sisi pelayan dan sesuai untuk pembangunan stack penuh.

JavaScript tidak memerlukan pemasangan kerana ia sudah dibina dalam pelayar moden. Anda hanya memerlukan editor teks dan penyemak imbas untuk memulakan. 1) Dalam persekitaran penyemak imbas, jalankan dengan memasukkan fail HTML melalui tag. 2) Dalam persekitaran Node.js, selepas memuat turun dan memasang node.js, jalankan fail JavaScript melalui baris arahan.

Cara Menghantar Pemberitahuan Tugas di Quartz terlebih dahulu Apabila menggunakan pemasa kuarza untuk menjadualkan tugas, masa pelaksanaan tugas ditetapkan oleh ekspresi cron. Sekarang ...

Cara mendapatkan parameter fungsi pada rantaian prototaip dalam JavaScript dalam pengaturcaraan JavaScript, pemahaman dan memanipulasi parameter fungsi pada rantaian prototaip adalah tugas yang biasa dan penting ...

Analisis sebab mengapa kegagalan anjakan gaya dinamik menggunakan vue.js dalam pandangan web applet weChat menggunakan vue.js ...

Bagaimana untuk membuat permintaan serentak untuk pelbagai pautan dan hakim mengikut urutan untuk mengembalikan hasil? Dalam skrip Tampermonkey, kita sering perlu menggunakan pelbagai rantai ...


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

Dreamweaver CS6
Alat pembangunan web visual

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

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

ZendStudio 13.5.1 Mac
Persekitaran pembangunan bersepadu PHP yang berkuasa