概览
减少与 Nuxt 3 的差异,降低迁移到 Nuxt 3 的负担。
如果你正在开始一个全新的 Nuxt 3 项目,请跳过本节并前往 Nuxt 3 Installation。
Bridge 是一个前向兼容层,通过简单地安装并启用一个 Nuxt 模块,你就可以体验到许多新的 Nuxt 3 功能。
使用 Nuxt Bridge,你可以确保你的项目(几乎)为 Nuxt 3 做好准备,并可以逐步进行向 Nuxt 3 的迁移。
第一部
升级 Nuxt 2
确保你的开发服务器(nuxt dev)未在运行,删除任何包锁文件(package-lock.json 和 yarn.lock),并安装最新的 Nuxt 2 版本:
package.json
- "nuxt": "^2.16.3"
+ "nuxt": "^2.17.3"
然后,重新安装你的依赖:
npm install
yarn install
pnpm install
bun install
安装完成后,请确保开发和生产构建都按预期工作,然后再继续。
安装 Nuxt Bridge
将 @nuxt/bridge 和 nuxi 安装为开发依赖:
npm install -D @nuxt/bridge nuxi
yarn add --dev @nuxt/bridge nuxi
pnpm add -D @nuxt/bridge nuxi
bun add -D @nuxt/bridge nuxi
更新 nuxt.config
请确保在配置文件中避免使用任何 CommonJS 语法,例如 module.exports、require 或 require.resolve。这些语法将很快被弃用且不被支持。
你可以改用静态的 import、动态的 import() 和 export default。通过重命名为 nuxt.config.ts 使用 TypeScript 也是可行且推荐的。
nuxt.config.ts
import { defineNuxtConfig } from '@nuxt/bridge'
export default defineNuxtConfig({
bridge: false,
})
更新命令
现在应将 nuxt 命令改为 nuxt2 命令。
{
"scripts": {
- "dev": "nuxt",
+ "dev": "nuxt2",
- "build": "nuxt build",
+ "build": "nuxt2 build",
- "start": "nuxt start",
+ "start": "nuxt2 start"
}
}
在此处尝试运行一次 nuxt2。你会看到应用与之前一样可用。
(如果将 'bridge' 设置为 false,你的应用将像以前一样运行而不做任何更改。)
升级步骤
通过 Nuxt Bridge,可以分步骤向 Nuxt 3 迁移。 下面的 “升级步骤” 不需要一次性完成。
从 CommonJS 迁移到 ESM
Nuxt 3 原生支持 TypeScript 和 ECMAScript 模块。请查看 Native ES Modules 以获取更多信息和升级指南。