Guide
Essentials
- Installation
- Introduction
- The Kdu Instance
- Template Syntax
- Computed Properties and Watchers
- Class and Style Bindings
- Conditional Rendering
- List Rendering
- Event Handling
- Form Input Bindings
- Components Basics
Components In-Depth
- Component Registration
- Props
- Custom Events
- Slots
- Dynamic & Async Components
- Handling Edge Cases
Transitions & Animation
- Enter/Leave & List Transitions
- State Transitions
Reusability & Composition
- Mixins
- Custom Directives
- Render Functions & JSX
- Plugins
- Filters
Tooling
- Single File Components
- TypeScript Support
- Production Deployment
Scaling Up
- Routing
- State Management
- Server-Side Rendering
- Security
Internals
- Reactivity in Depth
Migrating
- Migration to Kdu 2.7
Meta
- Meet the Team
TypeScript Support
Kdu CLI provides built-in TypeScript tooling support.
Official Declaration in NPM Packages
A static type system can help prevent many potential runtime errors, especially as applications grow. That’s why Kdu ships with official type declarations
for TypeScript - not only in Kdu core, but also for kdu-router
and kdux
as well.
Since these are published on NPM, and the latest TypeScript knows how to resolve type declarations in NPM packages, this means when installed via NPM, you don’t need any additional tooling to use TypeScript with Kdu.
Recommended Configuration
|
Note that you have to include strict: true
(or at least noImplicitThis: true
which is a part of strict
flag) to leverage type checking of this
in component methods otherwise it is always treated as any
type.
See TypeScript compiler options docs for more details.
Development Tooling
Project Creation
Kdu CLI 3 can generate new projects that use TypeScript. To get started:
|
Editor Support
For developing Kdu applications with TypeScript, we strongly recommend using Visual Studio Code, which provides great out-of-the-box support for TypeScript.
Basic Usage
To let TypeScript properly infer types inside Kdu component options, you need to define components with Kdu.component
or Kdu.extend
:
|
Class-Style Kdu Components
If you prefer a class-based API when declaring components, you can use the officially maintained kdu-class-component
decorator:
|
Augmenting Types for Use with Plugins
Plugins may add to Kdu’s global/instance properties and component options. In these cases, type declarations are needed to make plugins compile in TypeScript. Fortunately, there’s a TypeScript feature to augment existing types called module augmentation.
For example, to declare an instance property $myProperty
with type string
:
|
After including the above code as a declaration file (like my-property.d.ts
) in your project, you can use $myProperty
on a Kdu instance.
|
You can also declare additional global properties and component options:
|
The above declarations allow the following code to be compiled:
|
Annotating Return Types
Because of the circular nature of Kdu’s declaration files, TypeScript may have difficulties inferring the types of certain methods. For this reason, you may need to annotate the return type on methods like render
and those in computed
.
|
If you find type inference or member completion isn’t working, annotating certain methods may help address these problems. Using the --noImplicitAny
option will help find many of these unannotated methods.
Annotating Props
|
If you find validator not getting type inference or member completion isn’t working, annotating the argument with the expected type may help address these problems.