TypeScript reflect-metadata 结合方法装饰器实现的一个自定义语法检查的例子
生活随笔
收集整理的這篇文章主要介紹了
TypeScript reflect-metadata 结合方法装饰器实现的一个自定义语法检查的例子
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
reflect-metadata
例子:
import 'reflect-metadata';function validate(target: Object,key: string,descriptor: PropertyDescriptor ) {const originalFn = descriptor.value;// 獲取參數的編譯期類型const designParamTypes = Reflect.getMetadata('design:paramtypes', target, key);descriptor.value = function (...args: any[]) {args.forEach((arg, index) => {const paramType = designParamTypes[index];const result = arg.constructor === paramType|| arg instanceof paramType;if (!result) {throw new Error(`Failed for validating parameter: ${arg} of the index: ${index}`);}});return originalFn.call(this, ...args);} }class C {@validatesayRepeat(word: string, x: number) {return Array(x).fill(word).join('');} }const c = new C(); c.sayRepeat('hello', 2); // pass c.sayRepeat('', 'lol' as any); // throw an error方法裝飾器里包含的描述器形狀如下:
通過反射 API,提取出來的方法參數分別為 String 和 Number:
Reflect.getMetadata 的輸入和輸出的文檔如下:
可見,我們的自定義 validate 函數,一定程度上模擬了 TypeScript 編譯器的工作。
就算有開發人員在調用 sayRepeat 方法時,用 as any 的方式繞過了編譯器的靜態語法檢查,在運行時,我們的 @validate 裝飾器實現,也會將這種違規的行為檢測出來。
更多Jerry的原創文章,盡在:“汪子熙”:
總結
以上是生活随笔為你收集整理的TypeScript reflect-metadata 结合方法装饰器实现的一个自定义语法检查的例子的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 美团数据:五一期间生活服务业线上消费,较
- 下一篇: 特斯拉国产全系涨价2千元,会再次引领涨价