zoukankan      html  css  js  c++  java
  • [TypeScript] Reflection and Decorator Metadata

    TypeScript allows you to emit decorator metadata which enables more powerful features through reflection. This lesson show you how decorators and reflection fit together and how to configure your own decorators to use reflection.

    For now, if we look at the compiled file:

    var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
        var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
        if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
        else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
        return c > 3 && r && Object.defineProperty(target, key, r), r;
    };
    function addAge(age) {
        return function (targetClass) {
            return (function () {
                function class_1() {
                    this.age = age;
                    this.name = new targetClass().name;
                }
                return class_1;
            }());
        };
    }
    var Person = (function () {
        function Person() {
            this.name = "Johnn";
        }
        Person = __decorate([
            addAge(30)
        ], Person);
        return Person;
    }());
    var john = new Person();
    console.log(john); // {name: "Johnn", age: 30}

    It decorates addAge to Person class. 

    Now if we enable "emitDecoratorMetadata" in tsconfig.json:

    {
        "compilerOptions": {
            "rootDir": "src",
            "module": "commonjs",
            "target": "es5",
            "noImplicitAny": false,
            "sourceMap": false,
            "outDir": "./dist",
            "noEmitOnError": true,
            "experimentalDecorators": true,
            "emitDecoratorMetadata": true
        },
        "exclude": [
            "node_modules",
            "typings/main",
            "typings/main.d.ts"
        ]
    }

    Compile the files again, now we get:

    var Person = (function () {
        function Person() {
            this.name = "Johnn";
        }
        Person = __decorate([
            addAge(30), 
            __metadata('design:paramtypes', [])
        ], Person);
        return Person;
    }());

    It also add metadata.

    Install: 

    npm install reflect-metadata crypto --save

    Index.html:

    <script>
        System.config({
            packages: {
                "dist": {
                    "defaultExtension": "js",
                    "main": "main"
                },
                "rxjs": {
                    "defaultExtension": "js"
                }
            },
            map: {
                "lodash": "https://npmcdn.com/lodash@4.13.1",
                "rxjs": "node_modules/rxjs",
                "reflect-metadata": "node_modules/reflect-metadata/Reflect.js",
                "crypto": "node_modules/crypto/sha1.js",
            }
        });
    
        System.import("dist")
    </script>

    main.ts:

    import 'reflect-metadata';
    function example(){ return function(targetClass){ const types = Reflect.getMetadata('design:paramtypes', targetClass); console.log(types); return targetClass } } @example() class Person{ constructor(name: string, age: number){ } } new Person("John", 10);

    So in the example() fucntion, we console log out types, it will show:

    That means we were able to make it generic, so that any class that comes through into this example decorator, we can look up its types and then use those types to modify or pass into the constructor, and return the class decorated however we want.

  • 相关阅读:
    分享2021年陆陆续续看过的电影-附电影名单
    LEPUS开源数据库监控系统-开源的MySQL/Oracle/MongoDB/Redis一站式数据库专业级性能监控系统
    分享2021年陆陆续续读过的书-附书单
    Jmeter压测报错:Non HTTP response code: java.net.ConnectExceptionexception的解决办法
    adb安装apk包时提示:device unauthorized
    Pyhton AES_cbc解密
    appium— Android定位webView里面的UI元素
    appium自动化测试实战
    Appium + Python环境搭建(移动端自动化)
    selenium自动化定位方法
  • 原文地址:https://www.cnblogs.com/Answer1215/p/5574234.html
Copyright © 2011-2022 走看看