版本升级
#
版本说明飞冰的脚手架从 ice-scripts@1.x
到 ice-scripts@2.x
到 icejs 经过了三个大的版本变化,这些版本变化都是结合我们的业务实践以及用户诉求不断演进的,在能力和规范性上都在不断提高,核心的一些差别:
维度\版本 | icejs 2.x | icejs 1.x | ice-scripts 2.x | ice-scripts 1.x |
---|---|---|---|---|
定位 | 研发框架 | 研发框架 | 构建工具 | 构建工具 |
升级原因 | Webpack 5&Vite | 从构建工具到研发框架 | 工程配置插件化 | 统一管理工程配置 |
配置文件 | build.json | build.json | ice.config.js | package.json(buildConfig) |
文档地址 | 访问 | 访问 | 访问 | 访问 |
发布时间 | 2021.09 | 2020.02 | 2019.06 | 2018.02 |
可渐进升级性 | 好 | 好 | 不好 | 不好 |
插件能力 | 工程+运行时 | 工程+运行时 | 工程 | 无 |
工程配置 | 强 | 强 | 强 | 弱 |
运行时配置 | 默认支持 | 默认支持 | 默认不支持 | 默认不支持 |
SSR | 支持 | 支持 | 不支持 | 不支持 |
SSG | 支持 | 不支持 | 不支持 | 不支持 |
可渐进升级性「好」意味着整体设计较为稳定,未来的版本变化用户可以低成本的渐进升级。
#
从 icejs 1.x 升级caution
不推荐旧版本直接升级到 2.0 的 Vite 模式,建议先升级到 Webpack 模式,再按需迁移到 Vite 模式
#
1. 依赖版本升级package.json:
#
2. 工程配置升级icejs 2.x 移除了已废弃的工程配置和插件,并将一些优化逻辑默认内置:
详细说明请查阅 工程配置。
#
3. 运行时 API 升级#
核心 API在 icejs 1.x 中已提示废弃的 API,在 2.0 版本中完全移除:
#
状态管理方案在 1.x 中已提示废弃的用法,在 2.0 版本中完全移除:
- 不再支持自动初始化 store,推荐开发者按需求创建自己的
store.[ts|js]
,请按照文档进行升级 。 - Model 中使用
reducers&effects
替代actions: {}
写法,请按照文档进行升级 。 - 内置的 immer 从 6.x 升级到最新版本 9.x
#
权限管理方案2.0 中权限方案不再耦合状态管理,直接基于 React Context 实现,更加轻量,开发者端的 API 无任何变化。
#
请求数据方案将内置的 axios 版本从 0.19.x
升级到 0.21.x
。
#
4. 工程依赖版本变化框架内置的一些工程依赖也同时做了升级,理论上对于项目没有影响,可视具体情况来看:
#
5. 自定义插件迁移如果对框架进行了深度定制,并且开发了自定义的插件,需要关注插件相关 API 的变化。
#
内置规则名变更#
工程 API 变化#
运行时 API 变化框架运行时插件 API 变化如下:
#
从 ice-scripts 2.x 迁移#
1. 修改 package.json 依赖icejs 基于 build-scripts 内置了工程开发构建能力,不在需要单独依赖 ice-scripts,同时相关插件也进行了一次重构优化。
#
2. 修改配置文件icejs 提供 build.json
文件用于工程配置,因此需要将 ice.config.js
配置迁移到 build.json
中,具体如下:
假设你的 ice.config.js
配置如下:
新建 build.json
文件:(icejs 默认入口文件为 app.(js|ts)
,因此不需要单独配置 entry)
然后新建 build.plugin.js
文件,将自定义的 chainWebpack 配置移到新建的 build.plugin.js
中:
最后删除 ice.config.js
配置文件。
#
3. 修改应用入口文件将原有应用入口为 src/index.js
需要修改为 src/app.js
,具体修改如下:
假设你的 src/index.js
文件内容如下:
新建 src/app.js
文件:
最后,删除 src/index.js
文件
#
4. 其他文件修改icejs 规范和强约束了项目的目录结构,因此只需要按照规范就行编辑即可,不在需要额外的引用
- 删除
src/router.jsx
文件 - 移动
src/config/routes.js
路由配置至src/routes.js
中 - 在
.gitignore
中新增.ice/
目录 - 在根目录下新建
tsconfig.json
文件,配置详见 - 如果项目存在
src/models/*
、src/pages/*/model.js
或者src/pages/*/models/*
的目录文件,需要在build.json
中配置store: false
- 如果你的项目已经使用 icestore 且版本小于 1.0.0 版本,可以选择按需升级或者在
build.json
中配置store: false
关闭内置的方案
#
从 ice-scripts 1.x 迁移#
1. 修改 package.json 依赖icejs 支持了 ice-scripts 工程开发构建能力,不在需要单独依赖 ice-scripts,修改为 ice.js 即可。
#
2. 修改配置文件icejs 提供 build.json
文件用于工程配置,因此需要将 .webpackrc.js
配置迁移到 build.json
中,假设你的 .webpackrc.js
配置如下:
新建 build.json
文件
然后新建 build.plugin.js
文件,将自定义的插件配置移到新建的 build.plugin.js
中:
同时将自定义的插件引入到 build.json
中,最后删除 .webpackrc.js
配置文件。
#
3. 禁用运行时能力由于 icejs 相比 ice-scripts 除了提供工程能力外,还提供了运行时扩展的能力,因此对于 ice-scripts 的项目提供了禁用运行时能力的功能,确保最小化的升级和只使用工程能力。
在 build.json
中配置 disableRuntime 选项即可:
#
更新主题配置如果你的 package.json
中存在 buildConfig
和 themeConfig
配置,则需要将该配置移置 build.json
文件中。
更新后的 build.json
如下:
#
更新 proxyConfig如果你的 package.json
中存在 proxyConfig
配置,则需要将该配置移置 build.json
文件中,并将 proxyConfig
更新为 proxy
。
更新后的 build.json 项如下。
#
更新 scripts 脚本最后将 package.json
中启动项目的脚本替换如下:
通过以上步骤即可基于 ice-scripts@1.x
升级到 ice.js
,如果还存在其他配置或者升级失败,可以通过飞冰社区群与我们联系。