gpt4 book ai didi

angular - 打包 Angular 库以支持 Angular 8、9 和 10 的正确方法

转载 作者:行者123 更新时间:2023-12-04 13:55:51 25 4
gpt4 key购买 nike

随着 Angular 10 的发布,我将用于构建库 + 演示应用程序的 Angular 版本更新到版本 10。
通常,这进展顺利,并且该库与以前版本的 Angular 保持兼容,但此版本似乎并非如此(针对 Angular 9 的先前版本构建适用于 Angular 8)。
输出 typescript 定义文件包括:

import * as ɵngcc0 from '@angular/core';

...

static ɵfac: ɵngcc0.ɵɵFactoryDef<QrCodeComponent, never>;
static ɵcmp: ɵngcc0.ɵɵComponentDefWithMeta<QrCodeComponent, "qr-code", never, { "value": "value"; "size": "size"; "errorCorrectionLevel": "errorCorrectionLevel"; }, {}, never, never>;
在 Angular 8 项目中使用时会导致这样的错误:
 ERROR in node_modules/ng-qrcode/lib/qr-code.component.d.ts(7,25): error TS2694: Namespace '"/ngqrcode-ng8-test/node_modules/@angular/core/core"' has no exported member 'ɵɵFactoryDef'.
node_modules/ng-qrcode/lib/qr-code.component.d.ts(8,18): error TS2314: Generic type 'ɵɵComponentDefWithMeta' requires 6 type argument(s).
node_modules/ng-qrcode/lib/qr-code.directive.d.ts(13,25): error TS2694: Namespace '"/ngqrcode-ng8-test/node_modules/@angular/core/core"' has no exported member 'ɵɵFactoryDef'.
我使用以下方法全新创建了测试 angular 8 项目:
npx @angular/cli@^8 new ngqrcode-ng8-test
您可以在此处查看我对此更改的 WIP 拉取请求: https://github.com/mnahkies/ng-qrcode/pull/8
注意:我的编译器选项中已经有 enableIvy false :
"angularCompilerOptions": {
"enableIvy": false
}
有没有办法使用 Angular v10 构建一个与 Angular v8 保持兼容性的库?

最佳答案

angular 10 有两个重大变化:

  • 10 需要 tslib 2.0.0 对比 <10 需要 tslib < 2.0.0,
  • 10 使用 typescript 3.9 vs. < 10 需要 typescript < 3.9

  • 我认为您无法在一个包中打包 8、9 和 10 的库:-)

    关于angular - 打包 Angular 库以支持 Angular 8、9 和 10 的正确方法,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62620989/

    25 4 0
    Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
    广告合作:1813099741@qq.com 6ren.com