ThinkChat2.0新版上线,更智能更精彩,支持会话、画图、阅读、搜索等,送10W Token,即刻开启你的AI之旅 广告
>[success] # reflect-metadata ~~~ 1.需要安装这个库:npm install reflect-metadata --save 2.在定义类或者类方法的时候,可以设置一些元数据,我们可以获取 到在类与类方法上添加的元数据,用的方法就是 Reflect Metadata。 元数据指的是描述东西时用的数据。 3.这个库具体干啥我还没太懂,后续会死磕这个 ~~~ * 参考文章 [宁浩网](https://ninghao.net/blog/7384) [reflect-metadata api官方文档](https://github.com/rbuckton/reflect-metadata) >[info] ## 使用说明 ~~~ 1.这个库将会配合接下来的实战验证篇章,其中主要用到了两个方法, 对这两个方法做详细说明方便后续理解 ~~~ >[danger] ##### getMetadata -- 获取映射对应的数据 ~~~ 1.这个方法在官方api的英文 -- get metadata value of a metadata key on the prototype chain of an object or property,通过有道翻译的意思是:获取对象或 属性原型链上的元数据键的元数据值 2.我理解的意思是找到对应映射关系的'key',里面的的'admin' 相当于所对应的'value' ,通过'getMetadata'方法中的'key' 去寻找在映射时候添加的'value',在修饰类和类中 属性的时候使用略有差异 2.1.当去找'类'所映射的对应关系使用,第一个参数是创建映射时候的'key',第二个 参数是这个'类' 2.2.当去找'类中属性'对应的映射关系时候,三个参数,第一个参数是创建映射时候的'key' ,第二个参数是这个'实例',第三个是实例中所对应的具体'属性',其实可以很容易理解这里 为什么用的是实例,因为有了实例才有了属性 ~~~ * 案例一 ~~~ 1.通过案例一可以看出,可以用'reflect-metadata' 修饰类和类中的属性,本质上 和装饰器一样,其中'role' 相当于映射关系得到 ~~~ ~~~ @Reflect.metadata('role', 'admin') class Post { @Reflect.metadata('role', 'admin') name = '' } const metadataClass = Reflect.getMetadata('role', Post,); const metadataObj = Reflect.getMetadata('role', new Post(),'name'); console.log(metadataClass);// admin console.log(metadataObj); // admin ~~~ >[danger] ##### defineMetadata -- 自定义映射 ~~~ 1.除了上面'Reflect.metadata' 这种来给'类' 和 '属性' 增加映射关系,还可以 通自带的api'defineMetadata ' 来增加自定义的映射,这里和上面一样有两种 传参使用方法 1.1 当只有这 三个参数'metadataKey,metadataValue, target'修饰类的 1.2 当有这 四个参数'metadataKey,metadataValue, target, propertyKey' 修饰属性 2.参数详细解释: 2.1 metadataKey -- 设置映射的'key' 2.2 metadataValue -- 映射'key' 对应的'value' 2.3 target -- 需要映射对应的类 或者 实例 2.4 propertyKey 实例上的属性 ~~~ ~~~ /** * 创建一个自定义的映射关系存储 * @param metadataKey 映射的key * @param metadataValue 映射key 对应的value值 * @param target 映射需要的对应的类 或者实例 * @param propertyKey 实例上的属性 * **/ function customDecorator(metadataKey, metadataValue) { return ( target, propertyKey) =>{ Reflect.defineMetadata(metadataKey,metadataValue, target, propertyKey) } } class Post { @customDecorator('role', ['1']) name = '' } const post = new Post() let rg = Reflect.getMetadata('role',post, 'name') console.log(rg) // ["1"] rg.push('2') rg = Reflect.getMetadata('role',post, 'name') console.log(rg) // ["1", "2"] ~~~