這篇文章給大家分享的是有關(guān)TypeScript中Reflect Metadata怎么用的內(nèi)容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。
成都創(chuàng)新互聯(lián)公司是網(wǎng)站建設(shè)專家,致力于互聯(lián)網(wǎng)品牌建設(shè)與網(wǎng)絡(luò)營銷,專業(yè)領(lǐng)域包括網(wǎng)站設(shè)計、成都網(wǎng)站設(shè)計、電商網(wǎng)站制作開發(fā)、微信小程序、微信營銷、系統(tǒng)平臺開發(fā),與其他網(wǎng)站設(shè)計及系統(tǒng)開發(fā)公司不同,我們的整合解決方案結(jié)合了恒基網(wǎng)絡(luò)品牌建設(shè)經(jīng)驗和互聯(lián)網(wǎng)整合營銷的理念,并將策略和執(zhí)行緊密結(jié)合,且不斷評估并優(yōu)化我們的方案,為客戶提供全方位的互聯(lián)網(wǎng)品牌整合方案!在定義類或者類方法的時候,可以設(shè)置一些元數(shù)據(jù),我們可以獲取到在類與類方法上添加的元數(shù)據(jù),用的方法就是 Reflect Metadata。元數(shù)據(jù)指的是描述東西時用的數(shù)據(jù)。
在 TypeScript 里使用 Reflect Metadata 需要做下面這樣的配置:
{ "compilerOptions": { "experimentalDecorators": true , "emitDecoratorMetadata": true }, }
然后在項目里安裝 reflect-metadata 這個包:
npm install reflect-metadata --save
然后做個實驗:
import 'reflect-metadata'; @Reflect.metadata('role', 'admin') class Post {} const metadata = Reflect.getMetadata('role', Post); console.log(metadata); // admin
先導(dǎo)入 reflect-metadata 這個包,然后在定義的 Post 類的上面用 Reflect.metadata 裝飾器添加了一條元數(shù)據(jù),role 是這條元數(shù)據(jù)的名字,admin 是我們給這條數(shù)據(jù)設(shè)置的對應(yīng)的值。
稍后如果想獲取到在類上添加的這些元數(shù)據(jù),可以使用 Reflect.getMetadata 方法,role 是元數(shù)據(jù)的名字,Post 是對應(yīng)的類的名字。執(zhí)行上面代碼,會返回 admin 這個字符串。
自定義裝飾器
在上面的例子里我們用了 Reflect.metadata 設(shè)置的元數(shù)據(jù)。我們也可以自定義一個裝飾器去完成同樣的事情。像下面這樣:
import 'reflect-metadata'; function Role(name: string): ClassDecorator { return target => { Reflect.defineMetadata('role', name, target); }; } @Role('admin') class Post {} const metadata = Reflect.getMetadata('role', Post); console.log(metadata);
Role 是自定義的一個裝飾器,接收一個 name 參數(shù),這是一個裝飾器工廠,返回的是 ClassDecorator。返回的東西應(yīng)該是個適合在類上使用的裝飾器,所以接收一個 target 參數(shù),這個東西就是類的構(gòu)造方法。在方法里用 Reflect.defineMetadata 方法設(shè)置了一個自定義的元數(shù)據(jù)叫 role,對應(yīng)的值是 name,也就是使用這個裝飾器的時候提供的參數(shù)值,第三個參數(shù)是 target,就是要添加元數(shù)據(jù)的那個類。
有了這個自定義的裝飾器,使用它的時候可以像這樣: @Role('admin'),功能就是在它裝飾的類的上面添加了一條叫 role 的元數(shù)據(jù),設(shè)置的對應(yīng)的值是 admin。
感謝各位的閱讀!關(guān)于“TypeScript中Reflect Metadata怎么用”這篇文章就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,讓大家可以學(xué)到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機、免備案服務(wù)器”等云主機租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。
分享名稱:TypeScript中ReflectMetadata怎么用-創(chuàng)新互聯(lián)
標(biāo)題路徑:http://www.rwnh.cn/article10/djgodo.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制網(wǎng)站、網(wǎng)站營銷、網(wǎng)站設(shè)計公司、網(wǎng)站導(dǎo)航、自適應(yīng)網(wǎng)站、網(wǎng)站改版
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容