Jadual Kandungan
1. Partial : Buat semua atribut Pilihan
2. Required : Buat semua atribut diperlukan
3. Readonly : Buat Jenis Baca sahaja
4. Pick : Ekstrak atribut yang ditentukan
5. Omit : Tidak termasuk atribut yang ditentukan
6. Record : Tentukan jenis pemetaan nilai kunci
7. Exclude dan Extract : taipkan penapisan
8. NonNullable : Keluarkan null dan tidak ditentukan
9. Parameters dan ReturnType : Analisis Jenis Fungsi
10. Awaited : Menganalisis hasil janji yang mendalam
Rumah hujung hadapan web tutorial js Jenis Utiliti Typescript Anda Harus Menguasai

Jenis Utiliti Typescript Anda Harus Menguasai

Jul 30, 2025 am 03:42 AM

Partial Buat semua atribut pilihan dan sesuai untuk operasi kemas kini; 2. Diperlukan Buat semua atribut yang diperlukan untuk memastikan konfigurasi lengkap; 3. ReadOnly Buat jenis baca sahaja untuk mengelakkan pengubahsuaian tidak sengaja; 4. Pilih ekstrak atribut yang ditentukan untuk objek tanaman; 5. Menghilangkan tidak termasuk atribut yang ditentukan, yang biasa digunakan untuk pemprosesan DTO; 6. Rekod mentakrifkan pemetaan nilai kunci, sesuai untuk penghalaan atau pemetaan negara; 7. Tidak termasuk tidak termasuk jenis yang boleh diperuntukkan, ekstrak mengekstrak jenis yang boleh diperuntukkan untuk penapisan jenis bersama; 8. Tidak dapat dibuang Keluarkan null dan tidak ditentukan untuk meningkatkan keselamatan jenis; 9. Parameter dan Parameter Fungsi Ekstrak Ekstrak dan jenis pulangan secara berasingan untuk memudahkan pemprosesan fungsi pesanan yang lebih tinggi; 10. Ditunggu -tunggu Parses nilai akhir janji bersarang, sesuai untuk derivasi jenis asynchronous. Jenis praktikal ini adalah alat teras untuk meningkatkan kecekapan dan jenis keselamatan dalam pembangunan TypeScript. Selepas menguasai, anda dapat meningkatkan daya tahan dan keteguhan kod anda dengan ketara.

Jenis Utiliti TypeScript Anda Harus Menguasai

Jenis utiliti TypeScript adalah alat yang sangat diperlukan dalam pembangunan, yang dapat membantu anda mengendalikan jenis dengan lebih cekap dan meningkatkan penyelenggaraan kod dan keselamatan jenis. Menguasai jenis alat terbina dalam ini membolehkan anda menjadi selesa apabila berurusan dengan penukaran jenis yang kompleks. Berikut adalah jenis praktikal teras yang setiap pemaju TypeScript harus mahir.

Jenis Utiliti TypeScript Anda Harus Menguasai

1. Partial<t></t> : Buat semua atribut Pilihan

Partial<t></t> berguna apabila anda mahu semua sifat objek menjadi pilihan. Ia sering digunakan untuk mengemas kini operasi atau mengkonfigurasi objek.

 pengguna antara muka {
  ID: nombor;
  Nama: String;
  E -mel: String;
}

Function UpdateUser (ID: Nombor, Perubahan: Partial <suser>) {
  // kemas kini hanya medan masuk}

Dengan cara ini, changes hanya boleh mengandungi name , email , atau kosong.

Jenis Utiliti TypeScript Anda Harus Menguasai

Nota: Partial adalah cetek, dan sifat objek bersarang tidak akan secara automatik menjadi pilihan.


2. Required<T> : Buat semua atribut diperlukan

Bertentangan dengan Partial , Required<T> bertukar semua sifat pilihan ke dalam yang diperlukan. Sesuai untuk senario di mana anda ingin memastikan bahawa semua bidang objek konfigurasi dihuni.

Jenis Utiliti TypeScript Anda Harus Menguasai
 konfigurasi antara muka {
  Apiurl?: String;
  Timeout?: Nombor;
  Retries?: Nombor;
}

const defaultconfig: diperlukan <config> = {
  Apiurl: &#39;https://api.example.com&#39;,
  Timeout: 5000,
  Retries: 3,
};

Walaupun antara muka asal adalah pilihan, Required memaksa anda untuk menyediakan semua bidang.


3. Readonly<T> : Buat Jenis Baca sahaja

Menghalang objek daripada diubahsuai tanpa disangka -sangka. Sesuai untuk pemalar, pengurusan negeri, atau parameter dalam fungsi yang tidak mahu diubah suai.

 titik antara muka {
  x: nombor;
  y: nombor;
}

Const Origin: ReadOnly <toint> = {x: 0, y: 0};
// asal.x = 10; // ❌ Ralat: Tidak dapat memberikan nilai

Menggunakan Readonly untuk objek besar atau pokok negeri boleh dengan berkesan mengelakkan kesan sampingan.


4. Pick<T, K> : Ekstrak atribut yang ditentukan

Pilih beberapa bidang yang anda sayang dari jenis dan bina jenis baru. Ideal untuk penanaman tindak balas API atau pemilihan medan bentuk.

 pengguna antara muka {
  ID: nombor;
  Nama: String;
  E -mel: String;
  Kata Laluan: String;
}

Jenis publicUser = Pick <user, &#39;id&#39; | &#39;Nama&#39;>;
// {id: nombor; Nama: String}

Elakkan mendedahkan medan sensitif (seperti password ) sambil menyimpan jenis selamat.


5. Omit<T, K> : Tidak termasuk atribut yang ditentukan

Bertentangan dengan Pick , Omit membantu anda menghapuskan medan tertentu. Sangat praktikal apabila mengendalikan DTO (objek pemindahan data).

 Taipkan selamat = omit <user, &#39;kata laluan&#39;>;
// {id: nombor; Nama: String; E -mel: String}

Ia lebih ringkas daripada manual Pick semua bidang yang tidak sensitif, terutamanya apabila terdapat banyak bidang.


6. Record<K, T> : Tentukan jenis pemetaan nilai kunci

Record sangat sesuai apabila anda memerlukan objek yang kunci adalah satu jenis dan nilai yang lain.

 jenis laluan = rekod <string, () => string>;

Laluan Const: Laluan = {
  Laman Utama: () => &#39;/&#39;,
  profil: () => &#39;/profil&#39;,
  Tetapan: () => &#39;/Tetapan&#39;,
};

Ia juga biasa digunakan untuk pemetaan konfigurasi, penghitungan negara, dll.

Contoh yang lebih ketat:

 Taip status = &#39;Memuatkan&#39; | &#39;Kejayaan&#39; | &#39;Ralat&#39;;
Mesej Const: Rekod <Status, String> = {
  Memuat: &#39;Memuatkan ...&#39;,
  Kejayaan: &#39;Operasi berjaya&#39;,
  ralat: &#39;ada ralat&#39;,
};

Jika anda menulis kurang atau menulis satu lagi negeri, TypeScript akan melaporkan ralat.


7. Exclude<T, U> dan Extract<T, U> : taipkan penapisan

  • Exclude<T, U> : tidak termasuk jenis yang boleh diberikan kepada anda dari t
  • Extract<T, U> : ekstrak jenis t yang boleh diberikan kepada anda
 Taip status = &#39;Idle&#39; | &#39;Memuatkan&#39; | &#39;Kejayaan&#39; | &#39;Ralat&#39;;
Taip LoadingStates = Extract <Status, &#39;Memuatkan&#39; | &#39;Idle&#39;>; // &#39;idle&#39; | &#39;Memuatkan&#39;
Jenis ralatonly = tidak termasuk <status, &#39;idle&#39; | &#39;Memuatkan&#39; | &#39;Kejayaan&#39;>; // &#39;ralat&#39;

Sangat berkuasa dalam operasi jenis bersyarat dan kesatuan.


8. NonNullable<T> : Keluarkan null dan tidak ditentukan

Pastikan jenis tidak mengandungi null atau undefined berguna apabila berurusan dengan generik yang mungkin mengandungi nilai null.

 Taip Maybestring = String | NULL | tidak ditentukan;
taipkan pastiString = nonnullable <abeldestring>; // String

Digunakan dengan pengawal jenis, ia dapat meningkatkan ketepatan kesimpulan jenis.


9. Parameters<T> dan ReturnType<T> : Analisis Jenis Fungsi

Mengekstrak parameter dan jenis nilai pulangan dari jenis fungsi amat berguna untuk fungsi pesanan tinggi atau alat ujian.

 fungsi createUser (nama: string, umur: nombor): {id: nombor; Nama: String; umur: nombor} {
  kembali {id: date.now (), nama, umur};
}

taip args = parameter <typeof createuser>; // [String, Nombor]
jenis hasil = returnType <typeof createUser>; // {id: nombor; Nama: String; Umur: Nombor}

Ia boleh digunakan untuk merangkum logik umum seperti fungsi, log, dan cache.


10. Awaited<T> : Menganalisis hasil janji yang mendalam

Sesuai untuk mengendalikan jenis pulangan async/await atau Promise.then Kemudian, ia boleh menghuraikan janji bersarang dengan betul.

 taipkan deeppromise = janji <janji <janji <string >>>;
jenis nilai = ditunggu -tunggu <sepeppromise>; // String

fungsi async fetchuser () {
  kembali {id: 1, nama: &#39;Alice&#39;};
}

jenis pengguna = menunggu <returnType <typeof fetchuser >>; // {id: nombor; Nama: String}

Ia lebih tepat daripada .then() jenis kesimpulan, terutamanya dalam senario asynchronous kompleks.


Pada dasarnya itu sahaja. Jenis -jenis praktikal ini tidak "menunjukkan kemahiran", tetapi alat yang benar -benar dapat meningkatkan kecekapan dan keselamatan ketika menulis TypeScript setiap hari. Adalah disyorkan untuk cuba menggunakannya dalam projek, sebagai contoh:

 Taipkan UpdateUserDTO = Omit <Partial <suser>, &#39;ID&#39;>;
Taip Apiresponse <t> = {data: t; Status: &#39;Kejayaan&#39;} | {error: string; Status: &#39;Ralat&#39;};
Taipkan dataFromResponse <t> = ekstrak <ditunggu -tunggu <t>, {status: &#39;kejayaan&#39;}> [&#39;data&#39;];

Tidak rumit, tetapi mudah diabaikan. Menguasai mereka dan jenis anda benar -benar pengenalan.

Atas ialah kandungan terperinci Jenis Utiliti Typescript Anda Harus Menguasai. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Tutorial PHP
1535
276
Skop dan konteks JavaScript maju Skop dan konteks JavaScript maju Jul 24, 2025 am 12:42 AM

Skop JavaScript menentukan skop kebolehcapaian pembolehubah, yang dibahagikan kepada skop global, fungsi dan tahap blok; Konteks menentukan arah ini dan bergantung kepada kaedah panggilan fungsi. 1. Skop termasuk skop global (boleh diakses di mana sahaja), skop fungsi (hanya sah dalam fungsi), dan skop peringkat blok (biarkan dan const sah dalam {}). 2. Konteks pelaksanaan mengandungi objek pembolehubah, rantaian skop dan nilai -nilai ini. Ini menunjukkan kepada global atau tidak ditentukan dalam fungsi biasa, kaedah panggilan kaedah ke objek panggilan, pembina menunjuk ke objek baru, dan juga boleh ditentukan secara jelas oleh panggilan/memohon/mengikat. 3. Penutupan merujuk kepada fungsi mengakses dan mengingati pembolehubah skop luaran. Mereka sering digunakan untuk enkapsulasi dan cache, tetapi boleh menyebabkan

Meneroka Peraturan Paksaan Jenis dalam JavaScript Meneroka Peraturan Paksaan Jenis dalam JavaScript Jul 21, 2025 am 02:31 AM

Pemutus jenis adalah tingkah laku secara automatik menukar satu jenis nilai kepada jenis lain dalam JavaScript. Senario biasa termasuk: 1. Apabila menggunakan pengendali, jika satu sisi adalah rentetan, sisi lain juga akan ditukar kepada rentetan, seperti '5' 5. Hasilnya ialah "55"; 2. 3. Null mengambil bahagian dalam operasi berangka dan akan ditukar kepada 0, dan undefined akan ditukar kepada NAN; 4. Masalah yang disebabkan oleh penukaran tersirat boleh dielakkan melalui fungsi penukaran eksplisit seperti nombor (), rentetan (), dan boolean (). Menguasai peraturan ini membantu

Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Vue 3 Composition API vs Pilihan API: Perbandingan Terperinci Jul 25, 2025 am 03:46 AM

COMPOSISAPI dalam VUE3 lebih sesuai untuk logik dan jenis derivasi yang kompleks, dan OptionsAPI sesuai untuk senario dan pemula yang mudah; 1. Optionsapi menganjurkan kod mengikut pilihan seperti data dan kaedah, dan mempunyai struktur yang jelas tetapi komponen kompleks dipecah -pecah; 2. CompositionAPI menggunakan persediaan untuk menumpukan logik yang berkaitan, yang kondusif untuk penyelenggaraan dan penggunaan semula; 3. Compositionapi menyedari penggunaan semula logik bebas konflik dan parameternya melalui fungsi kompos yang lebih baik daripada Mixin; 4. CompositionAPI mempunyai sokongan yang lebih baik untuk typescript dan derivasi jenis yang lebih tepat; 5. Tidak terdapat perbezaan yang signifikan dalam jumlah prestasi dan pembungkusan kedua -duanya; 6.

Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Menguasai Corak Konvensyen JavaScript: Pekerja Web vs Java Threads Jul 25, 2025 am 04:31 AM

Terdapat perbezaan penting antara pekerja web JavaScript dan Javathreads dalam pemprosesan serentak. 1. JavaScript mengamalkan model tunggal-thread. WebWorkers adalah benang bebas yang disediakan oleh penyemak imbas. Ia sesuai untuk melaksanakan tugas-tugas yang memakan masa yang tidak menghalang UI, tetapi tidak dapat mengendalikan DOM; 2. Java menyokong multithreading sebenar dari tahap bahasa, yang dibuat melalui kelas thread, sesuai untuk logik serentak dan pemprosesan sisi serentak; 3. WebWorkers menggunakan postmessage () untuk berkomunikasi dengan benang utama, yang sangat selamat dan terpencil; Benang Java boleh berkongsi ingatan, jadi isu penyegerakan perlu diberi perhatian; 4. Pekerja web lebih sesuai untuk pengkomputeran selari depan, seperti pemprosesan imej, dan

Bagaimana untuk membuat dan menambahkan elemen di JS? Bagaimana untuk membuat dan menambahkan elemen di JS? Jul 25, 2025 am 03:56 AM

Gunakan document.createelement () untuk membuat elemen baru; 2. Sesuaikan elemen melalui textContent, classlist, setAttribute dan kaedah lain; 3. Gunakan kaedah tambahan () atau lebih fleksibel () untuk menambah elemen ke DOM; 4. Secara pilihan menggunakan InsertBefore (), sebelum () dan kaedah lain untuk mengawal kedudukan penyisipan; Proses lengkap adalah untuk membuat → Sesuaikan → Tambah, dan anda boleh mengemas kini kandungan halaman secara dinamik.

Membina alat CLI dengan node.js Membina alat CLI dengan node.js Jul 24, 2025 am 03:39 AM

Memulakan projek dan buat pakej.json; 2. Buat skrip kemasukan index.js dengan shebang; 3. Daftar perintah melalui medan bin dalam pakej.json; 4. Gunakan Yargs dan perpustakaan lain untuk menghuraikan parameter baris arahan; 5. Gunakan ujian tempatan NPMLink; 6. Tambah bantuan, versi dan pilihan untuk meningkatkan pengalaman; 7. Secara pilihan menerbitkan melalui NPMPublish; 8. Secara pilihan mencapai penyelesaian automatik dengan YARGS; Akhirnya buat alat CLI praktikal melalui struktur yang munasabah dan reka bentuk pengalaman pengguna, tugas automasi lengkap atau mengedarkan widget, dan berakhir dengan ayat lengkap.

Jenis Bersyarat Lanjutan dalam TypeScript Jenis Bersyarat Lanjutan dalam TypeScript Aug 04, 2025 am 06:32 AM

Jenis Keadaan Lanjutan TypeScript Melaksanakan penghakiman logik antara jenis melalui Textendsu? X: Y Sintaks. Keupayaan terasnya ditunjukkan dalam jenis keadaan yang diedarkan, kesimpulan jenis kesimpulan dan pembinaan alat jenis kompleks. 1. Jenis bersyarat diedarkan dalam parameter jenis kosong dan secara automatik boleh memecah jenis bersama, seperti toarray untuk mendapatkan rentetan [] | number []. 2. Menggunakan Pengagihan untuk Membina Alat Penapisan dan Pengekstrakan: Tidak termasuk Kecualikan Jenis Melalui Textendsu? Tidak pernah: T, Ekstrak Ekstrak Persamaan melalui Textendsu? 3

Mikro Frontends Architecture: Panduan Pelaksanaan Praktikal Mikro Frontends Architecture: Panduan Pelaksanaan Praktikal Aug 02, 2025 am 08:01 AM

Microfrontendssolvescalingchallengesinlargeteamsbyenablingindependentdevelopmentanddeployment.1) chooseanInintegrationstration: useModulefederationInwebPack5formruntimeLoadingandtrueindectivence, Build-timeIntegrationForseMlesetups, Oriframes/Web

See all articles