TypeScript中的裝飾器用法
一、裝飾器
裝飾器是一種特殊類型的聲明,它能夠被附加到類聲明,方法,屬性或參數(shù)上,可以修改類的行為。
通俗的講裝飾器就是一個(gè)方法,可以注入到類、方法、屬性參數(shù)上來(lái)擴(kuò)展類、屬性、方法、參數(shù)的功能。
常見(jiàn)的裝飾器有:類裝飾器、屬性裝飾器、方法裝飾器、參數(shù)裝飾器
裝飾器的寫(xiě)法:普通裝飾器(無(wú)法傳參) 、 裝飾器工廠(可傳參)
裝飾器是過(guò)去幾年中js最大的成就之一,已是Es7的標(biāo)準(zhǔn)特性之一
二、類裝飾器:
類裝飾器在類聲明之前被聲明(緊靠著類聲明)。
類裝飾器應(yīng)用于類構(gòu)造函數(shù),可以用來(lái)監(jiān)視,修改或替換類定義。 傳入一個(gè)參數(shù)
1、 類裝飾器:普通裝飾器(無(wú)法傳參)
function logClass(params: any) {
console.log(params);
// params 就是當(dāng)前類
params.prototype.apiUrl = '動(dòng)態(tài)擴(kuò)展的屬性';
params.prototype.run = function () {
console.log('我是一個(gè)run方法');
}
}
@logClass
class HttpClient {
constructor() {
}
getData() {
}
}
var http: any = new HttpClient();
console.log(http.apiUrl);
http.run();2、 類裝飾器:裝飾器工廠(可傳參)
function logClass(params: string) {
return function (target: any) {
console.log(target);
console.log(params);
target.prototype.apiUrl = params;
}
}
@logClass('http://www.itying.com/api')
class HttpClient {
constructor() {
}
getData() {
}
}
var http: any = new HttpClient();
console.log(http.apiUrl);下面是一個(gè)用類裝飾器重載構(gòu)造函數(shù)的例子。
類裝飾器表達(dá)式會(huì)在運(yùn)行時(shí)當(dāng)作函數(shù)被調(diào)用,類的構(gòu)造函數(shù)作為其唯一的參數(shù)。
如果類裝飾器返回一個(gè)值,它會(huì)使用提供的構(gòu)造函數(shù)來(lái)替換類的聲明。
function logClass(target: any) {
console.log(target);
return class extends target {
apiUrl: any = '我是修改后的數(shù)據(jù)';
getData() {
this.apiUrl = this.apiUrl + '----';
console.log(this.apiUrl);
}
}
}
@logClass
class HttpClient {
public apiUrl: string | undefined;
constructor() {
this.apiUrl = '我是構(gòu)造函數(shù)里面的apiUrl';
}
getData() {
console.log(this.apiUrl);
}
}
var http = new HttpClient();
http.getData();三、屬性裝飾器
屬性裝飾器表達(dá)式會(huì)在運(yùn)行時(shí)當(dāng)作函數(shù)被調(diào)用,傳入下列2個(gè)參數(shù):
1、對(duì)于靜態(tài)成員來(lái)說(shuō)是類的構(gòu)造函數(shù),對(duì)于實(shí)例成員是類的原型對(duì)象。
2、成員的名字。
//類裝飾器
function logClass(params: string) {
return function (target: any) {
// console.log(target);
// console.log(params);
}
}
//屬性裝飾器
function logProperty(params: any) {
return function (target: any, attr: any) {
console.log(target);
console.log(attr);
target[attr] = params;
}
}
@logClass('xxxx')
class HttpClient {
@logProperty('http://itying.com')
public url: any | undefined;
constructor() {
}
getData() {
console.log(this.url);
}
}
var http = new HttpClient();
http.getData();四、方法裝飾器
它會(huì)被應(yīng)用到方法的 屬性描述符上,可以用來(lái)監(jiān)視,修改或者替換方法定義。
方法裝飾會(huì)在運(yùn)行時(shí)傳入下列3個(gè)參數(shù):
1、對(duì)于靜態(tài)成員來(lái)說(shuō)是類的構(gòu)造函數(shù),對(duì)于實(shí)例成員是類的原型對(duì)象。
2、成員的名字。
3、成員的屬性描述符。
五、方法參數(shù)裝飾器
參數(shù)裝飾器表達(dá)式會(huì)在運(yùn)行時(shí)當(dāng)作函數(shù)被調(diào)用,傳入下列3個(gè)參數(shù):
1、對(duì)于靜態(tài)成員來(lái)說(shuō)是類的構(gòu)造函數(shù),對(duì)于實(shí)例成員是類的原型對(duì)象。
2、參數(shù)的名字。
3、參數(shù)在函數(shù)參數(shù)列表中的索引。
到此這篇關(guān)于TypeScript裝飾器的文章就介紹到這了。希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
深入解讀JavaScript中的Hoisting機(jī)制
這篇文章主要介紹了JavaScript中的Hoisting機(jī)制,涉及到JS中變量聲明的相關(guān)問(wèn)題,需要的朋友可以參考下2015-08-08
JavaScript入門(mén)教程(7) History歷史對(duì)象
JavaScript中的History歷史對(duì)象包含了用戶已瀏覽的 URL 的信息,是指歷史對(duì)象指瀏覽器的瀏覽歷史。2009-01-01
JavaScript中String.match()方法的使用詳解
這篇文章主要介紹了JavaScript中String.match()方法的使用詳解,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06
Javascript中indexOf()和lastIndexOf應(yīng)用方法實(shí)例
這篇文章主要介紹了JavaScript中的indexOf()和lastIndexOf()方法使用實(shí)例,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),有需要的朋友可以參考下。2016-08-08
uni-app自定義組件components導(dǎo)入失敗或頁(yè)面不顯示文本等解決方法
這篇文章主要給大家介紹了關(guān)于uni-app自定義組件components導(dǎo)入失敗或頁(yè)面不顯示文本等的解決方法,眾所周知Uni-app支持使用自定義組件,文中通過(guò)圖文介紹的非常詳細(xì),需要的朋友可以參考下2023-08-08
簡(jiǎn)介JavaScript中valueOf()方法的使用
這篇文章主要介紹了簡(jiǎn)介JavaScript中valueOf()方法的使用,是JS入門(mén)學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下2015-06-06

