javascript - 带有全局变量后备的 Typescript UMD
问题描述
我想用 Typescript 编写一个与浏览器兼容的 javascript 库,如 jQuery,并带有一个用于访问库 API 的全局变量。
这是一个例子...
索引.ts
export * from './lib/number';
./lib/number.ts
export function double(value: number): number {
return value * 2;
}
tsconfig.json
{
"compilerOptions": {
"incremental": true,
"target": "es5",
"outDir": "build/main",
"rootDir": "src",
"moduleResolution": "node",
"module": "UMD"
}
}
输出
index.js
var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });
}) : (function(o, m, k, k2) {
if (k2 === undefined) k2 = k;
o[k2] = m[k];
}));
var __exportStar = (this && this.__exportStar) || function(m, exports) {
for (var p in m) if (p !== "default" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);
};
(function (factory) {
if (typeof module === "object" && typeof module.exports === "object") {
var v = factory(require, exports);
if (v !== undefined) module.exports = v;
}
else if (typeof define === "function" && define.amd) {
define(["require", "exports", "./lib/number"], factory);
}
})(function (require, exports) {
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
__exportStar(require("./lib/number"), exports);
});
//# sourceMappingURL=index.js.map
如何设置打字稿以在窗口全局变量上生成后备?
window.MYLIBRARY = factory(require, exports);
解决方案
推荐阅读
- oracle - 在 Firefox 或 Chrome 等浏览器上没有任何配置的情况下,如何在 OBIEE 12c 登录页面中忘记密码?
- ios - 科尔多瓦打印机插件不打印
- python - 解释 Python 子集化
- django - django-allauth) 如何从 url 中的访问代码中获取访问令牌?
- react-native - React-Native:通常使用 react-native-image-crop-picker 和 Camera 使用 openCamera 时在 android 上崩溃
- javascript - 'Form' 未定义 react/jsx-no-undef
- coq - 如何在 Coq 中使用多个“0”表示法
- dart - 如何在颤动/飞镖中替换 $ 符号
- python - 使用 Python 3 向 Google 的控制台发送命令
- google-apps-script - 如何通过谷歌脚本自动打开超链接单元格?