Sử dụng Functions trong TypeScript

Giống như JavaScript, bạn sử dụng từ khóa function để khai báo một function trong TypeScript: functionname(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ụ: functionadd(a:number, b:number):number{return a + b;}

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

functionname(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ụ:

functionadd(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 oftype'"10"'is not assignable to parameter oftype'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ụ:

functionecho(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ụ:

functionadd(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 :

functionadd(x:number, y:number):number{return x + y;}letadd2=function(x:number, y:number):number{return x + y;};console.log(add(10,20));//output 30console.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;}letadd4=(x:number, y:number)=>{return x + y;}letadd5=(x:number, y:number)=> x + y;letadd6:(a:number, b:number)=>number=function(x:number, y:number){return x + y;};console.log(add3(10,20));//output 30console.log(add4(10,20));//output 30console.log(add5(10,20));//output 30console.log(add6(10,20));//output 30

Nguồn: viblo.asia

Bài viết liên quan

WebP là gì? Hướng dẫn cách để chuyển hình ảnh jpg, png qua webp

WebP là gì? WebP là một định dạng ảnh hiện đại, được phát triển bởi Google

Điểm khác biệt giữa IPv4 và IPv6 là gì?

IPv4 và IPv6 là hai phiên bản của hệ thống địa chỉ Giao thức Internet (IP). IP l

Check nameservers của tên miền xem website trỏ đúng chưa

Tìm hiểu cách check nameservers của tên miền để xác định tên miền đó đang dùn

Mình đang dùng Google Domains để check tên miền hàng ngày

Từ khi thông báo dịch vụ Google Domains bỏ mác Beta, mình mới để ý và bắt đầ