- vừa được xem lúc

Sử dụng Functions trong TypeScript

0 0 20

Người đăng: Gấu con

Theo Viblo Asia

Giống như JavaScript, bạn sử dụng từ khóa function để khai báo một function trong TypeScript:

function name(parameter: type, parameter:type,...): returnType { // do something
}

Không giống như JavaScript, TypeScript cho phép bạn sử dụng các loại chú thích cho các tham số và kiểu giá trị trả về của hàm.ví dụ:

function add(a: number, b: number): number { return a + b;
}

Hàm add() chấp nhận 2 tham số với loại chú thích là kiểu number.
Khi bạn gọi hàm add(), trình biên dịch TypeScript sẽ kiểm trả từng đối số được truyền vào hàm để đảm bảo rằng chúng là những giá trị số.
Trong ví dụ về hàm add(), bạn chỉ có thể truyền các số vào nó, không thể chuyển các giá trị của các kiểu khác.
Nếu bạn truyền vào 2 đối số là các strings vào hàm add(), nó sẽ trả về lỗi:

let sum = add('10', '20');

Error:

error TS2345: Argument of type '"10"' is not assignable to parameter of type 'number'

: number sau dấu ngoặc đơn là loại trả về của hàm. Hàm add() trả về một giá trị loại number.
Khi một hàm có kiểu trả về, trình biên dịch TypeScript sẽ kiểm tra mọi câu lệnh trả về so với kiểu trả về để đảm bảo rằng giá trị trả về tương thích với nó.
Nếu một hàm không trả về giá trị, bạn có thể sử dụng kiểu void làm kiểu trả về. Từ khóa void cho biết rằng hàm không trả về bất kỳ giá trị nào. Ví dụ:

function echo(message: string): void { console.log(message.toUpperCase());
}

Khi bạn không chú thích kiểu trả về, TypeScript sẽ cố gắng suy ra một kiểu thích hợp. Ví dụ:

function add(a: number, b: number) { return a + b;
}

Trong ví dụ này, trình biên dịch TypeScript cố gắng suy ra kiểu trả về của hàm add () thành kiểu số, cái được mong đợi.
Tuy nhiên, nếu một hàm có các nhánh khác nhau trả về các kiểu khác nhau, thì trình biên dịch TypeScript có thể suy ra kiểu union hoặc kiểu any.
Do đó, điều quan trọng là phải thêm chú thích kiểu vào một hàm càng nhiều càng tốt..

Ví dụ về một số loại khai báo hàm và sử dụng arrow function :

function add(x: number, y: number): number { return x + y;
} let add2 = function (x: number, y: number): number { return x + y;
};
console.log(add(10, 20)); //output 30
console.log(add2(10, 20)); //output 30 //Sử dụng với arrow function(mũi tên (=>) xuất hiện giữa các tham số và kiểu trả về.)
let add3 = (x: number, y: number) : number => { return x + y; } let add4 = (x: number, y: number) => { return x + y; } let add5 = (x: number, y: number) => x + y; let add6: (a: number, b: number) => number = function (x: number, y: number) { return x + y; }; console.log(add3(10, 20)); //output 30
console.log(add4(10, 20)); //output 30
console.log(add5(10, 20)); //output 30
console.log(add6(10, 20)); //output 30

Bình luận

Bài viết tương tự

- vừa được xem lúc

Giới thiệu Typescript - Sự khác nhau giữa Typescript và Javascript

Typescript là gì. TypeScript là một ngôn ngữ giúp cung cấp quy mô lớn hơn so với JavaScript.

0 0 500

- vừa được xem lúc

Type annotation vs Type Inference - Typescript

Trong bài viết này, chúng ta sẽ tìm hiểu kỹ về TypeScript bằng cách tìm hiểu sự khác biệt giữa kiểu chú thích và kiểu suy luận. Tôi sẽ cho rằng bạn có một số kinh nghiệm về JavaScript và biết về các kiểu cơ bản, như chuỗi, số và boolean.

0 0 32

- vừa được xem lúc

Type Annotation và Type Inference trong TypeScript là gì?

Khi làm việc với javascript chắc hẳn các bạn đã quá quen với việc dùng biến mà không cần phải quan tâm đến kiểu dữ liệu của nó là gì phải không? Đúng là mới đầu tiếp cận với Typescript mình cũng cảm thấy nó khá là phiền vì cần phải khai báo đủ type để nó chặt chẽ hơn. Lúc đó mình còn nghĩ: " JavaScr

0 0 25

- vừa được xem lúc

Tìm hiểu TypeScript và kiến thức cơ bản

TypeScript là gì. TypeScript sử dụng tất cả các tính năng của của ECMAScript 2015 (ES6) như classes, modules.

0 0 35

- vừa được xem lúc

TypeScript - P1: Vì sao TypeScript được yêu thích đến vậy?

Trải nghiệm thực tế. Trước khi là một Web Developer, tôi là một Mobile Developer và Java là thứ mà tôi từng theo đuổi.

0 1 58

- vừa được xem lúc

4 Tính năng rất hay từ TypeScript

Xin chào các bạn hôm nay mình xin chia sẽ những tính năng rất hay của TypeScript (TS), các bạn cùng tìm hiểu nhé. Ngoài việc set Type cho biến, tham số hay function thì ví dụ khi bạn nhìn vào một tham

0 0 82