一直在尝试学习如何创建/分发一个 npm 包,并且我已经编写了我的第一个使用 ResizeObserver API 的库,目前该 API 拥有大约 89.6% 的全球支持。
我想捆绑一个文件,其中也包含resize-observer-polyfill
库的一部分,因此有人可以将其导入为
import <library-name> from "<library-name>/polyfilled";
我已经使用TSDX来生成项目,目前只是发送 index.ts 文件以及 index.d.ts 类型文件。在 index.ts 文件中,有一个在内部使用调整大小观察器的函数。
我不确定如何创建设置来处理这个问题,如果它可以纯粹通过更改配置来包含它(TSDX 使用汇总)或者我需要做其他事情,比如动态导入模块,但是不确定这在捆绑包大小方面如何工作,以及是否会添加到整个库大小中。
// index.js
(async () => {
if (!ResizeObserver in window) {
const module = await import('resize-observer-polyfill');
window.ResizeObserver = module.ResizeObserver
}
}();
// main function exported
export default () => {
function loadResizeObserver() {
const ro = new ResizeObserver((entries) => {
// ...
})
}
}
处理向库添加 polyfill 的最佳方法是什么。或者如果需要,我应该只指向消费者添加的polyfill?