TypeScript, superset JavaScript yang ditaip kuat, membawa keupayaan semakan jenis yang mantap kepada pembangunan JavaScript. Keupayaan ini membantu pembangun menangkap ralat lebih awal dan menulis kod yang lebih boleh diselenggara. Antara ciri hebat TypeScript ialah Jenis Kesatuan dan Jenis Persimpangan. Jenis ini memberikan fleksibiliti dan ketepatan dalam menentukan jenis kompleks, yang boleh menjadi penting untuk aplikasi berskala besar.
Matlamat artikel ini adalah untuk menerangkan konsep kesatuan dan jenis persilangan dalam TypeScript. Kami akan menyelami contoh untuk menggambarkan cara jenis ini boleh digabungkan untuk mencipta definisi jenis yang lebih ekspresif. Menjelang akhir artikel ini, anda seharusnya mempunyai pemahaman yang kukuh tentang cara menggunakan jenis ini dengan berkesan dalam projek TypeScript anda.
Baiklah, tanpa berlengah lagi, mari kita selami.
Saya ada meme ini di bawah.
https://www.picturepunches.com/meme/317642
Terdapat peraturan yang tidak diperkatakan dalam seni perbualan: jangan sesekali bertanya kepada seorang wanita seusianya dan jangan sesekali meminta seorang lelaki gajinya. Tetapi mari kita tingkatkan kepentingan dan jadikan ini lebih menarik. Bayangkan peraturan ketiga: jangan sekali-kali meminta pengekod kiraan projek mereka yang belum selesai. Sesetengah rahsia sebaiknya dibiarkan dalam bayang-bayang—kerana sama ada umur, pendapatan atau projek sampingan yang terbengkalai, jawapan selalunya disertakan dengan cerita yang mungkin anda tidak bersedia untuk mendengarnya.
OK, mari fokus pada dua item pertama: lelaki dan wanita.
Dont ask 1 | Dont ask 2 | Should ask 1 | Should ask 2 | |
---|---|---|---|---|
Man | Salary | Relationship | Address | Full name |
Woman | Age | Weight | Address | Full name |
Dalam TypeScript kita boleh membuat jenis seperti ini:
type Person = { gender: 'man' | 'woman', dontAsk: 'salary' | 'relationship' | 'age' | 'weight' };
Masalah di sini jika kita mencipta objek berdasarkan jenis Orang
const person1: Person = { gender: 'man', dontAsk: 'weight', }; const person2: Person = { gender: 'woman', dontAsk: 'salary', };
Kedua-dua objek di atas tidak akan menunjukkan sebarang ralat jenis.
Jenis Persimpangan dan Kesatuan datang untuk menyelesaikan masalah ini.
A Jenis Kesatuan membolehkan pembolehubah menjadi salah satu daripada beberapa jenis. Dalam contoh kami:
{ gender: 'man', dontAsk: 'salary' | 'relationship' } | { gender: 'woman', dontAsk: 'weight' | 'size' }
Bahagian definisi jenis ini menyatakan bahawa Orang boleh menjadi salah satu daripada dua bentuk:
Fleksibiliti ini berguna apabila berurusan dengan data yang boleh mengambil pelbagai bentuk.
Satu Jenis Persimpangan menggabungkan berbilang jenis menjadi satu. Pembolehubah jenis persilangan mesti memenuhi semua jenis juzuk. Dalam contoh kami:
& { address?: string, fullName: string }
Bahagian definisi jenis ini menyatakan bahawa Orang mesti mempunyai:
Jenis Orang yang lengkap menggabungkan kedua-dua jenis kesatuan dan persimpangan:
type Person = ({ gender: 'man', dontAsk: 'salary' | 'relationship' } | { gender: 'woman', dontAsk: 'weight' | 'age' }) & { address?: string, fullName: string };
Objek Orang mesti sepadan dengan salah satu jenis kesatuan dan juga mesti menyertakan sifat yang ditakrifkan dalam jenis persimpangan. Berikut ialah beberapa objek Orang yang sah:
const person1: Person = { gender: 'man', dontAsk: 'salary', fullName: 'John Doe' }; const person2: Person = { gender: 'woman', dontAsk: 'weight', fullName: 'Jane Doe', address: '123 Main St' };
Jika tentukan person1 jangan minta umur, ini menunjukkan ralat. Dalam Kod Visual Studio yang telah dibina dalam sokongan untuk TypeScript, ia akan menunjukkan ralat apabila kita melayang objek.
Dalam TypeScript, Jenis Kesatuan membenarkan pembolehubah menjadi salah satu daripada beberapa jenis, manakala Jenis Persimpangan menggabungkan berbilang jenis menjadi satu. Dengan memahami dan menggunakan jenis ini, anda boleh menulis kod TypeScript yang lebih fleksibel dan mantap. Contoh jenis Orang menggambarkan cara menggabungkan konsep ini untuk mencipta definisi jenis yang kompleks dan tepat.
Menggunakan TypeScript dengan berkesan boleh meningkatkan kebolehselenggaraan kod dengan ketara. Apabila pembangun baharu menyertai pasukan anda, definisi jenis yang jelas mengurangkan keperluan untuk penerangan yang panjang lebar. Daripada mentafsir kod, pasukan boleh menumpukan pada membincangkan aliran dan matlamat projek, meningkatkan produktiviti dan kerjasama.
Atas ialah kandungan terperinci Jenis Kesatuan dan Persimpangan dalam TypeScript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!