Webpack树抖动 - 删除名为Entity

时间:2017-09-07 08:46:11

标签: webpack ionic2 tree-shaking

我偶然发现了一个非常奇怪的名字问题。我正在尝试在Ionic App中使用TypeScript库(TypeORM),它使用webpack来构建和编译应用程序。

TypeORM具有名为EntityAbstractEntity等实体的装饰器。当我导入并使用Entity装饰器时,不会被webpack标记为使用。当我切换到AbstractEntity时,它被标记为已使用。每个其他装饰器都被标记为已使用。

此Typescript类

import { Entity, Column, PrimaryGeneratedColumn } from 'typeorm';

@Entity()
export class User {
   @PrimaryGeneratedColumn()
   user_id_internal: number;

   @Column({unique: true})
   user_id: string;
   @Column()
   first_name: string;
   @Column()
   last_name: string;
}

被翻译成

var User = (function () {
   function User() {
   }
   return User;
}());
__decorate([
   Object(__WEBPACK_IMPORTED_MODULE_0_typeorm__["f" /* PrimaryGeneratedColumn */])(),
   __metadata("design:type", Number)
], User.prototype, "user_id_internal", void 0);
__decorate([
    Object(__WEBPACK_IMPORTED_MODULE_0_typeorm__["a" /* Column */])({ unique: true }),
    __metadata("design:type", String)
], User.prototype, "user_id", void 0);
__decorate([
    Object(__WEBPACK_IMPORTED_MODULE_0_typeorm__["a" /* Column */])(),
    __metadata("design:type", String)
], User.prototype, "first_name", void 0);
__decorate([
    Object(__WEBPACK_IMPORTED_MODULE_0_typeorm__["a" /* Column */])(),
    __metadata("design:type", String)
], User.prototype, "last_name", void 0);
User = __decorate([
    Object(__WEBPACK_IMPORTED_MODULE_0_typeorm__["b" /* Entity */])()
], User);

Entity被标记为未使用

// index.ts imports
/* unused harmony namespace reexport */
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_31__decorator_entities_Entity__ = __webpack_require__(382);

// Entity.ts exports
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__index__ = __webpack_require__(4);
/* unused harmony export Entity */

但是当我将Entity更改为AbstractEntity时,会将其标记为已使用

// index.ts
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_32__decorator_entities_AbstractEntity__ = __webpack_require__(555);
/* harmony namespace reexport (by used) */ __webpack_require__.d(__webpack_exports__, "a", function() { return __WEBPACK_IMPORTED_MODULE_32__decorator_entities_AbstractEntity__["a"]; });

// AbstractEntity.ts
/* harmony export (immutable) */ __webpack_exports__["a"] = AbstractEntity;
/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__index__ = __webpack_require__(4);

关于为什么的任何想法?

1 个答案:

答案 0 :(得分:0)

事实证明,Entity在主打字稿文件中导出了两次。编译器并没有抱怨它,但webpack似乎有问题。删除第二个导出修复了问题。