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.
(??) 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 (||).
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
.
<code class="language-javascript">let value = 0; let defaultValue = value || 10; console.log(defaultValue); // 输出:10</code>
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.
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.
<code class="language-typescript">let value: number | null | undefined = 0; let defaultValue = value ?? 10; console.log(defaultValue); // 输出:0</code>
Dalam contoh ini, value
ialah 0, yang bukan nol. Oleh itu, defaultValue
diberikan nilai 0, mengekalkan nilai yang dijangkakan.
null
atau undefined
. 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.
Salah satu kes penggunaan yang paling biasa untuk operator penggabungan nol ialah menyediakan nilai lalai untuk parameter fungsi.
<code class="language-typescript">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!</code>
Dalam contoh ini, fungsi greet
menggunakan operator penggabungan nol untuk memberikan nama lalai 'Tetamu' apabila argumen name
sama ada null
atau undefined
.
Pengendali penggabungan nol juga boleh digunakan untuk mengendalikan sifat pilihan dalam objek.
<code class="language-javascript">let value = 0; let defaultValue = value || 10; console.log(defaultValue); // 输出:10</code>
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
.
Pengendali penggabungan nol juga boleh digunakan untuk mengendalikan nilai nol dalam tatasusunan.
<code class="language-typescript">let value: number | null | undefined = 0; let defaultValue = value ?? 10; console.log(defaultValue); // 输出:0</code>
Dalam contoh ini, tatasusunan values
mengandungi nombor, null
dan undefined
. Operator penggabungan nol menggantikan nilai nol dengan 0.
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.
Anda boleh merantai berbilang operator penggabungan nol untuk memberikan berbilang nilai sandaran.
<code class="language-typescript">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!</code>
Dalam contoh ini, value
dan fallback1
adalah batal, jadi pengendali penggabungan nol jatuh kembali kepada fallback2
, yang mempunyai nilai 42.
Pengendali penggabungan nol boleh digabungkan dengan pengendali lain, seperti pengendali ternary, untuk mencipta ungkapan bersyarat yang lebih kompleks.
<code class="language-typescript">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}`);</code>
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.
Apabila menggunakan operator penggabungan nol, pastikan anda mengikuti amalan terbaik untuk memastikan kod anda jelas, boleh diselenggara dan bebas ralat.
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!