サクサク読めて、アプリ限定の機能も多数!
トップへ戻る
Switch 2
www.totaltypescript.com
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. Node 23 will soon be able to run TypeScript files without any extra configuration. Marco Ippolito, who has been driving TypeScript support in Node for the last year, landed a PR unflagging --experimental-strip-types in Node 23. Practically, this means a few things: You can create an
Total TypeScript: Essentials is a book for devs of all levels to learn advanced type manipulation and real-world application development patterns in TypeScript.Start Reading → JavaScript's developer experience has left you wanting more. With only basic autocompletion, limited refactoring support, and the constant fear of runtime errors, it was time to make the change. You have chosen wisely. But g
The Prettify helper is a utility type that takes an object type and makes the hover overlay more readable. type Prettify<T> = { [K in keyof T]: T[K]; } & {}; It's known by various names - Id, Compute, Unwrap - but each uses this same implementation. It's also not globally available in TypeScript - you'll need to define it yourself using the code above. #Example Let's imagine that you've got a type
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. In this article, we'll learn how to set up TypeScript to bundle a Node app. We'll be using: pnpm for package management. Node.js for running our code. TypeScript for type safety and for bundling our code. ES Modules as our module system. If you're interested in a setup involving ESB
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. TypeScript 5.5 will be dropping in the next couple of months. And thanks to one PR in particular, I already know it's going to be an incredible release. On Friday night, TypeScript merged Dan Vanderkam's PR to "Infer type predicates from function bodies using control flow analysis".
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. If you've worked with TypeScript and JSX for enough time, you'll probably have run into a situation where you want to restrict a component's children to be of a certain type. Let's say you're working on a Select component that takes Option components as children. You want to make su
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. #The Problem When you're working with React and TypeScript, you'll often encounter this kind of error: const onChange = (e) => {}; Parameter 'e' implicitly has an 'any' type. <input onChange={onChange} />; It's not always clear what type you should give to the e inside your onChange
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. React's props model is extremely powerful. One of its most useful features is the ability to pass a component as a prop. This lets you create composable pieces of UI, helping to make your components more reusable. The trouble is that this can often be difficult to type correctly. Le
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. tsconfig.json scares everyone. It's a huge file with a TON of potential options. But really, there are only a few configuration options you need to care about. Let's figure them out, and cheatsheet them. #The Package This article is so popular that I've bundled its recommendations i
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. #Quick Explanation JSX.Element and React.ReactElement are functionally the same type. They can be used interchangeably. They represent the thing that a JSX expression creates. import React from 'react'; // ---cut--- const node: JSX.Element = <div />; const node2: React.ReactElement
without ts-reset🚨 .json (in fetch) and JSON.parse both return any🤦 .filter(Boolean) doesn't behave how you expect😡 array.includes often breaks on readonly arrays with ts-reset👍 .json (in fetch) and JSON.parse return unknown✅ .filter(Boolean) behaves EXACTLY how you expect🥹 array.includes is widened to be more ergonomic🚀 And several more improvements!
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. #Quick Explanation You should use types by default until you need a specific feature of interfaces, like 'extends'. Interfaces can't express unions, mapped types, or conditional types. Type aliases can express any type. Interfaces can use extends, types can't. When you're working wi
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. Using useRef with native elements can be a bit of a pain. You need to specify the type of the element you're targeting, but it's not always clear what type you should be using. import React, { useRef } from "react"; const Component = () => { // What goes here? const audioRef = useRe
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. #Quick Explanation The empty object type - {} - doesn't behave how you expect in TypeScript. Instead of representing an empty object, it represents any value except null and undefined. This is because TypeScript's type system is structural, not nominal. Everything except null and un
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. TypeScript 5.2 introduces a new keyword - using - that you can use to dispose of anything with a Symbol.dispose function when it leaves scope. { const getResource = () => { return { [Symbol.dispose]: () => { console.log('Hooray!') } } } using resource = getResource(); } // 'Hooray!'
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. #Quick Breakdown As of TypeScript 5.1 and React 18, React.FC is now officially 'fine'. It no longer implicitly includes children in the props type. It no longer breaks if you return undefined, string, or number. I still recommend simply annotating props instead of using React.FC. Bu
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. You're an engineer. You're building something. The thing you're building probably has inputs - points at which data is injected. Let's say you're building a CLI called matt: matt run <something> Here, <something> is the input. It's the thing that tells the program what to do. It's t
Matt PocockMatt is a well-regarded TypeScript expert known for his ability to demystify complex TypeScript concepts. For the last few months, Donny (or kdy1 on GitHub) has been walking a long, lonely road. The author of swc, a native-speed replacement for Babel, has his eyes on another goal: rewriting TypeScript in Rust. stc is his attempt. It's a drop-in replacement for tsc supporting "all typing
The feature’s working. The tests are passing. But your IDE is a sea of red lines. TypeScript’s not happy again. Element implicitly has an ‘any’ type because expression of type ‘string’ can’t be used to index type ‘{ string: string | undefined; }’ No index signature with a parameter of type ‘string’ was found on type ‘{ string: string | undefined; }’ It’s impossible to Google. Every search result i
Get hands-on interactive practice with this free TypeScript tutorial and learn the foundational knowledge and skills you need to become a TypeScript Wizard. In this TypeScript tutorial you will: Learn to type variables, functions, and errors Become familiar with the TypeScript documentation Gain experience with modern TypeScript tooling Start now, and see why TypeScript’s an essential tool for mod
TypeScript is great for checking variables at the type level. For example, you can specify that the age property for a User should be a number. However, you can’t always be sure what you’re going to get from a form input. TypeScript will present an error if it’s not a number, but on its own it doesn’t know if a number is too low or too high to be realistic for your use case. There’s a similar prob
このページを最初にブックマークしてみませんか?
『Professional TypeScript Training by Matt Pocock』の新着エントリーを見る
j次のブックマーク
k前のブックマーク
lあとで読む
eコメント一覧を開く
oページを開く