Mengapa Tambah Jenis pada JavaScript?
Gambar ini: Anda gembira mengekod dalam JavaScript, apabila tiba-tiba - "Tidak boleh membaca 'nama' sifat yang tidak ditentukan". Ugh, kita semua pernah ke sana! TypeScript adalah seperti mempunyai rakan yang menangkap kesilapan ini sebelum ia berlaku.
Kisah Asal Usul
JavaScript adalah seperti Peter Parker sebelum gigitan labah-labah - berpotensi besar, tetapi terdedah kepada kemalangan. TypeScript ialah gigitan labah-labah yang memberikan kuasa besar JavaScript. Ia menambahkan sistem jenis yang membantu menangkap pepijat lebih awal dan menjadikan kod anda lebih dipercayai.
Pengembaraan TypeScript Pertama Anda
Mari kita mulakan dengan fungsi JavaScript yang mudah dan mengubahnya menjadi TypeScript:
// JavaScript function greet(name) { return "Hello, " + name + "!"; }
Sekarang, mari tambah beberapa keajaiban TypeScript:
// TypeScript function greet(name: string): string { return "Hello, " + name + "!"; }
Nampak itu : rentetan? Itu TypeScript memberitahu kami "fungsi ini mengambil rentetan dan mengembalikan rentetan". Sekarang cuba ini:
greet(123); // Error: Argument of type 'number' is not assignable to parameter of type 'string'
TypeScript baru sahaja menyelamatkan kami daripada pepijat yang berpotensi! ?
Jenis Asas: Kuasa Besar Baru Anda
Mari terokai beberapa jenis TypeScript asas:
// Basic types let heroName: string = "Spider-Man"; let age: number = 25; let isAvenger: boolean = true; let powers: string[] = ["web-slinging", "wall-crawling"]; // Object type let hero: { name: string; age: number; powers: string[]; } = { name: "Spider-Man", age: 25, powers: ["web-slinging", "wall-crawling"] };
Antara Muka: Mencipta Jenis Anda Sendiri
Antara muka adalah seperti cetak biru untuk objek. Ia sangat berguna untuk menentukan bentuk data anda:
interface Hero { name: string; age: number; powers: string[]; catchPhrase?: string; // Optional property } function introduceHero(hero: Hero): void { console.log(`I am ${hero.name}, and I'm ${hero.age} years old!`); if (hero.catchPhrase) { console.log(hero.catchPhrase); } } const spiderMan: Hero = { name: "Spider-Man", age: 25, powers: ["web-slinging", "wall-crawling"] }; introduceHero(spiderMan);
Jenis Alias: Jenis Tersuai Anda
Kadangkala anda ingin mencipta kombinasi jenis anda sendiri:
type PowerLevel = 'rookie' | 'intermediate' | 'expert'; interface Hero { name: string; powerLevel: PowerLevel; } const batman: Hero = { name: "Batman", powerLevel: "expert" // TypeScript will ensure this is one of the allowed values };
Generik: Fleksibiliti Terbaik
Generik adalah seperti kad bebas yang menjadikan kod anda lebih boleh digunakan semula:
function createHeroTeam<t>(members: T[]): T[] { return [...members]; } interface Superhero { name: string; power: string; } interface Villain { name: string; evilPlan: string; } const heroes = createHeroTeam<superhero>([ { name: "Iron Man", power: "Technology" }, { name: "Thor", power: "Lightning" } ]); const villains = createHeroTeam<villain>([ { name: "Thanos", evilPlan: "Collect infinity stones" } ]); </villain></superhero></t>
Contoh Dunia Sebenar: A Todo App
Mari bina apl todo ringkas dengan TypeScript:
interface Todo { id: number; title: string; completed: boolean; dueDate?: Date; } class TodoList { private todos: Todo[] = []; addTodo(title: string, dueDate?: Date): void { const todo: Todo = { id: Date.now(), title, completed: false, dueDate }; this.todos.push(todo); } toggleTodo(id: number): void { const todo = this.todos.find(t => t.id === id); if (todo) { todo.completed = !todo.completed; } } getTodos(): Todo[] { return this.todos; } } // Usage const myTodos = new TodoList(); myTodos.addTodo("Learn TypeScript with baransel.dev"); myTodos.addTodo("Build awesome apps", new Date("2024-10-24"));
TypeScript dengan React
TypeScript dan React adalah seperti mentega kacang dan jeli. Berikut ialah contoh ringkas:
interface Props { name: string; age: number; onSuperPower?: () => void; } const HeroCard: React.FC<props> = ({ name, age, onSuperPower }) => { return ( <div> <h2 id="name">{name}</h2> <p>Age: {age}</p> {onSuperPower && ( <button onclick="{onSuperPower}"> Activate Super Power! </button> )} </div> ); }; </props>
Petua dan Trik
- Mulakan Mudah: Mulakan dengan jenis asas dan tambah yang lebih kompleks secara beransur-ansur.
- Gunakan Pengkompil: Pengkompil TypeScript ialah rakan anda - perhatikan ralatnya.
- Jangan Terlalu Jenis: Kadang-kadang mana-mana pun boleh (tetapi gunakannya dengan berhati-hati!).
- Dayakan Mod Ketat: Tambahkan "ketat": benar pada tsconfig.json anda untuk perlindungan maksimum.
Gotcha Biasa dan Cara Membaikinya
// Problem: Object is possibly 'undefined' const user = users.find(u => u.id === 123); console.log(user.name); // Error! // Solution: Optional chaining console.log(user?.name); // Problem: Type assertions const input = document.getElementById('myInput'); // Type: HTMLElement | null const value = input.value; // Error! // Solution: Type assertion or type guard const value = (input as HTMLInputElement).value; // or if (input instanceof HTMLInputElement) { const value = input.value; }
Membungkus
TypeScript mungkin kelihatan seperti kerja tambahan pada mulanya, tetapi ia seperti mempunyai kuasa besar yang membantu anda menangkap pepijat sebelum ia berlaku. Mulakan secara kecil-kecilan, tambah lebih banyak jenis secara beransur-ansur dan sebelum anda mengetahuinya, anda akan tertanya-tanya bagaimana anda pernah hidup tanpanya!
Ingat:
- Jenis ialah rakan anda
- Penyusun ialah teman anda
- Amalan menjadikan sempurna
Atas ialah kandungan terperinci TypeScript: Cape Superhero JavaScript. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Perbezaan utama antara Python dan JavaScript ialah sistem jenis dan senario aplikasi. 1. Python menggunakan jenis dinamik, sesuai untuk pengkomputeran saintifik dan analisis data. 2. JavaScript mengamalkan jenis yang lemah dan digunakan secara meluas dalam pembangunan depan dan stack penuh. Kedua -duanya mempunyai kelebihan mereka sendiri dalam pengaturcaraan dan pengoptimuman prestasi yang tidak segerak, dan harus diputuskan mengikut keperluan projek ketika memilih.

Sama ada untuk memilih Python atau JavaScript bergantung kepada jenis projek: 1) Pilih Python untuk Sains Data dan Tugas Automasi; 2) Pilih JavaScript untuk pembangunan front-end dan penuh. Python disukai untuk perpustakaannya yang kuat dalam pemprosesan data dan automasi, sementara JavaScript sangat diperlukan untuk kelebihannya dalam interaksi web dan pembangunan stack penuh.

Python dan JavaScript masing -masing mempunyai kelebihan mereka sendiri, dan pilihan bergantung kepada keperluan projek dan keutamaan peribadi. 1. Python mudah dipelajari, dengan sintaks ringkas, sesuai untuk sains data dan pembangunan back-end, tetapi mempunyai kelajuan pelaksanaan yang perlahan. 2. JavaScript berada di mana-mana dalam pembangunan front-end dan mempunyai keupayaan pengaturcaraan tak segerak yang kuat. Node.js menjadikannya sesuai untuk pembangunan penuh, tetapi sintaks mungkin rumit dan rawan kesilapan.

Javascriptisnotbuiltoncorc; it'saninterpretedlanguagethatrunsonenginesoftenwritteninc .1) javascriptwasdesignedasalightweight, interpratedlanguageforwebbrowsers.2)

JavaScript boleh digunakan untuk pembangunan front-end dan back-end. Bahagian depan meningkatkan pengalaman pengguna melalui operasi DOM, dan back-end mengendalikan tugas pelayan melalui Node.js. 1. Contoh front-end: Tukar kandungan teks laman web. 2. Contoh backend: Buat pelayan Node.js.

Memilih Python atau JavaScript harus berdasarkan perkembangan kerjaya, keluk pembelajaran dan ekosistem: 1) Pembangunan Kerjaya: Python sesuai untuk sains data dan pembangunan back-end, sementara JavaScript sesuai untuk pembangunan depan dan penuh. 2) Kurva Pembelajaran: Sintaks Python adalah ringkas dan sesuai untuk pemula; Sintaks JavaScript adalah fleksibel. 3) Ekosistem: Python mempunyai perpustakaan pengkomputeran saintifik yang kaya, dan JavaScript mempunyai rangka kerja front-end yang kuat.

Kuasa rangka kerja JavaScript terletak pada pembangunan yang memudahkan, meningkatkan pengalaman pengguna dan prestasi aplikasi. Apabila memilih rangka kerja, pertimbangkan: 1.

Pengenalan Saya tahu anda mungkin merasa pelik, apa sebenarnya yang perlu dilakukan oleh JavaScript, C dan penyemak imbas? Mereka seolah -olah tidak berkaitan, tetapi sebenarnya, mereka memainkan peranan yang sangat penting dalam pembangunan web moden. Hari ini kita akan membincangkan hubungan rapat antara ketiga -tiga ini. Melalui artikel ini, anda akan mempelajari bagaimana JavaScript berjalan dalam penyemak imbas, peranan C dalam enjin pelayar, dan bagaimana mereka bekerjasama untuk memacu rendering dan interaksi laman web. Kita semua tahu hubungan antara JavaScript dan penyemak imbas. JavaScript adalah bahasa utama pembangunan front-end. Ia berjalan secara langsung di penyemak imbas, menjadikan laman web jelas dan menarik. Adakah anda pernah tertanya -tanya mengapa Javascr


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

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

Artikel Panas

Alat panas

MantisBT
Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Muat turun versi mac editor Atom
Editor sumber terbuka yang paling popular

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

Versi Mac WebStorm
Alat pembangunan JavaScript yang berguna

EditPlus versi Cina retak
Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod
