Rumah >hujung hadapan web >tutorial js >Jenis Kesatuan dan Persimpangan dalam TypeScript

Jenis Kesatuan dan Persimpangan dalam TypeScript

DDD
DDDasal
2025-01-06 08:07:44832semak imbas

Jenis Kesatuan dan Persimpangan dalam TypeScript

pengenalan

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.

Kajian Kes

Saya ada meme ini di bawah.

Union and Intersection Types in TypeScript

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.

Jenis Kesatuan

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:

  1. Objek dengan jantina: 'lelaki' dan jangan Tanya sama ada ‘gaji’ atau ’hubungan’.
  2. Objek dengan jantina: 'wanita' dan jangan Tanya sama ada 'berat' atau 'umur'.

Fleksibiliti ini berguna apabila berurusan dengan data yang boleh mengambil pelbagai bentuk.

Jenis Persimpangan

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:

  • Sifat alamat pilihan jenis rentetan.
  • Sifat nama penuh yang diperlukan jenis rentetan.

Menggabungkan Jenis Kesatuan dan Persimpangan

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.

Union and Intersection Types in TypeScript

Ringkasan

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!

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