demo 地址 https://stackblitz.com/edit/vitejs-vite-cvb6u1?file=src/App.ts
同样引入三个东西,第一种压缩前 44k ,第二种 17k ,第三种 9k
像这种兼容 commonjs 和 esm 的库,想要实现最优化打包大小每次 import 的时候是不是都要保证是从 es 目录下面单独引入的?
有没有插件可以实现把支持 esm 的库的引入都自动转成 es 目录下的引入?
import { List, NonEmptyList, Maybe } from 'purify-ts';
// import { Maybe } from 'purify-ts/Maybe';
// import { NonEmptyList } from 'purify-ts/NonEmptyList';
// import { List } from 'purify-ts/List';
// import { Maybe } from 'purify-ts/es/Maybe';
// import { NonEmptyList } from 'purify-ts/es/NonEmptyList';
// import { List } from 'purify-ts/es/List';
const columns = [
{ id: 1, itemIds: [1, 2] },
{ id: 2, itemIds: [3] },
];
function App() {
Maybe.of(1).chain((value) => Maybe.fromNullable(value).ifJust(console.log));
NonEmptyList.fromArray([1, 2, 3]).map(NonEmptyList.head).ifJust(console.log);
List.find(({ id }) => id === 1, columns).ifJust(console.log);
return 'hello';
}
const a = document.createElement('div');
a.innerText = App();
document.querySelector('#root')?.appendChild(a);
这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。
V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。
V2EX is a community of developers, designers and creative people.