支持 Top Level Await,Rust Farm v1.1.0 发布

⭐️Farm v1.1.0 支持了 Top Level AwaitNode 懒编译 等新特性,并修复了部分 Bug。

不了解 Farm?参考

一、新特性

1.1 Top Level Await

Farm 从 v1.1.0 开始支持 top level await,开箱即用,无需任何额外配置。 请注意,top level await 仅适用于**原生支持async/await的浏览器,当针对旧版浏览器时,使用 top level await 将引发运行时错误。

使用示例:

ts 复制代码
// data.json
[1, 2, 3]

// data.ts
const data = await import('./data.json');
// 使用顶层 await
export default await Promise.resolve(data.default);

// index.ts
import data from './data.ts'; // 直接 import 异步模块
console.log(data); // [1, 2, 3]

Farm 在 v1.1.0 中引入了 异步模块(async module) 的概念,使用 top-level wait 的模块将成为 异步模块,静态导入 异步模块 的模块也将是 异步模块。 对于上面的示例:data.ts异步模块,因为它使用了 top level awaitindex.ts 也是 异步模块,因为它静态导入 异步模块 data.ts

Farm top level await 完全按照 top level await 的规范实现,包括编译时和运行时两部分都进行了支持

对于没有使用 top level await 的项目,所有模块都是 同步模块(sync module),编译产物跟之前比不会有任何差异。

async module 是 Farm 内部的概念,一般用户不会关心它,但是对于运行时插件作者来说,如果想扩展 farm 模块系统,可能需要注意模块的执行可能是异步的

1.2 Node 懒编译

之前 懒编译 仅适用于浏览器,从 v1.1.0 开始,在 targetEnvnode 时也可以使用 懒编译。 Node 的懒编译可以大大提升 SSR Node 侧编译性能,例如,如果有多个动态路由,那么这些动态路由的代码直到执行时才会进行编译,能大大减少大型项目的编译时间,提升开发体验。

例子:

ts 复制代码
// dynamic.ts
export const a = 'aaa';

// index.ts
console.log('script start');

import('./dynamic.js').then((mod) => {
  console.log('111' + mod.a);
});

在上面的例子中,只有当执行 index.ts时,dynamic.ts 才会被编译。

1.3 swc_core 更新到 v0.90

swc_corev0.88更新为0.90,修复了一些 SWC 底层的 bug。如果您使用了 SWC 插件,请确保该插件与swc_core v0.90 兼容。

二、Bug 修复

2.1 lib 构建不再注入 polyfill

对于 library 的构建,polyfill 应由上层 APP 来进行处理,因此 v1.1.0 开始,不再对 library 注入 polyfill.

ts 复制代码
export default defineConfig({
    compilation: {
        input: { index: './index.ts' }
    }
});

在上面的配置中,Farm 不再为 ./index.ts 注入 polyfill。

修复随机的 cache panic

由于并发问题,频繁保存时,可能会出现如下 cache 导致的 panic:

文本 复制代码
thread '<unnamed>' panicked at crates\plugin_runtime\src\render_resource_pot\mod.rs:307:12:
failed to write resource pot to runtime object cache: Os { code: 2, kind: NotFound, message: "系统找不到指定的文件。" }

v1.1.0 修复了该问题

Changelog

Minor

  • 71b6bab7:壮举:当条目不是 html 时禁用 polyfill
  • ef1b39bc:支持 Top level await
  • 86d17342:将 SWC 核心版本提升至 v0.90

Patch

  • 3581ee5e:支持针对节点时的延迟编译
  • 4e8ebbcc:支持cli根路径选项
  • 更新了依赖项 ef1b39bc
    • @farmfe/runtime@0.11.0
    • @farmfe/runtime-plugin-hmr@3.5.1
    • @farmfe/runtime-plugin-import-meta@0.2.0
相关推荐
数据潜水员5 分钟前
解决el-carousel 前后图片切换闪烁问题
前端·javascript·vue.js
Source.Liu7 分钟前
【Iced】`lib.rs` 源码分析 - `iced_core` 核心库
rust·iced
nothing&nowhere8 分钟前
Web 漏洞分析:Reflected / Stored / DOM XSS 实战(完整翻译)
前端·web安全·xss
feng68_8 分钟前
Discuz! X5 高性能+高可用
linux·运维·服务器·前端·后端·高性能·高可用
知行合一。。。9 分钟前
XSS-跨站脚本攻击
前端·安全·xss
Y君10 分钟前
在我当开发工程师的第10年,我完成了一次转向
前端·agent
optimistic_chen14 分钟前
【Vue入门】scoped与组件通信
linux·前端·javascript·vue.js·前端框架·组件通信
SuperEugene20 分钟前
前端空值处理规范:Vue 实战避坑,可选链、?? 兜底写法|项目规范篇
前端·javascript·vue.js
前端百草阁20 分钟前
Vue3 Diff 算法详解
前端·javascript·vue.js·算法·前端框架
im_AMBER21 分钟前
前后端对接: ESM配置与React Router
前端·javascript·学习·react.js·性能优化·前端框架·ecmascript