如何处理 javascript 捆绑包中的版权声明?

How to handle Copyright notice in javascript bundle?

我正在编写几个小演示来向同事解释装饰器(打字稿),这时我注意到我的捆绑包有一个 Microsoft 版权声明,这使得我的整个文件对所有人免费(并且由 MS 制作)。

应该如何有效地处理这个问题(如果我创建的东西不是免费的)?

我使用 Typescript 3.1 进行编译和打包汇总。

代码:

import { isNotUndefined, isNotNullOrUndefined } from "goodcore/Test";

function deprecated<S>(instead?: string, message?: string) {
    // Logic removed for brevity...
}

class Car {
    @deprecated()
    public turnIgnitionKey() {
        this.start();
    }
    public pressStartButton() {
        this.start();
    }
    private start() {
        console.log("Running!");
    }
}

let car = new Car();
car.turnIgnitionKey();
car.pressStartButton();

和bundle beginning(最后一个函数是我的,之前的是MS):

'use strict';

/*! *****************************************************************************
Copyright (c) Microsoft Corporation. All rights reserved.
Licensed under the Apache License, Version 2.0 (the "License"); you may not use
this file except in compliance with the License. You may obtain a copy of the
License at http://www.apache.org/licenses/LICENSE-2.0

THIS CODE IS PROVIDED ON AN *AS IS* BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
KIND, EITHER EXPRESS OR IMPLIED, INCLUDING WITHOUT LIMITATION ANY IMPLIED
WARRANTIES OR CONDITIONS OF TITLE, FITNESS FOR A PARTICULAR PURPOSE,
MERCHANTABLITY OR NON-INFRINGEMENT.

See the Apache Version 2.0 License for specific language governing permissions
and limitations under the License.
***************************************************************************** */

function __decorate(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 __metadata(metadataKey, metadataValue) {
    if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(metadataKey, metadataValue);
}

function isNullOrUndefined(arg) {
    return arg === undefined || arg === null;
}

@JGoodgive,

您可以在您创建的每个 JavaScript 文件上方添加您自己的自定义许可证,这样当它们捆绑在一起时,您的许可证文件应该显示在您的 JS 代码上方。

/*! *****************************************************************************
Copyright (c) <Author>. All rights reserved.
<Custom license text here>
***************************************************************************** */

// Your JS code below your custom license 

Rollup 将所有需要的东西打包到输出文件中。你看到的是来自 tslib 模块的 Typescript 助手。

您可以用 tslib 库导入替换该代码(并摆脱 MS 许可证)。

添加到您的 rollup.config.js 以下设置:external: ["tslib"]。不幸的是,您需要将 tslib 模块添加到项目的依赖项(或 peerDependencies)中。

查看以下对话了解更多详情: https://github.com/ezolenko/rollup-plugin-typescript2/issues/58(关于外部设置)

https://github.com/ReactiveX/rxjs/issues/2436#issuecomment-371585945(关于依赖与 peerDependency 的问题)

这里是关于助手的: https://mariusschulz.com/blog/external-helpers-library-in-typescript

我在汇总配置中添加了 rollup-plugin-terser 并将注释设置为 false,以便删除所有注释。

...
import { terser } from 'rollup-plugin-terser';
...
plugins: [
    ...
    terser({ format: { comments: false } }),
    ...
]