5.1 KiB
常见问题
问题查找渠道
- 对应模块的 GitHub 仓库 issue 搜索
- 从 Google 搜索问题
- 从 百度 搜索问题
- 在列表找不到问题可以到 issues 提问
- 需要讨论的问题到 discussions
依赖问题
git pull 后依赖更新
在 Monorepo 项目下,需要养成每次 git pull 后执行 pnpm install 的习惯,因为经常会有新的依赖包加入。项目在 lefthook.yml 已配置自动执行,但有时会出现问题,建议手动执行。
依赖安装失败
- 尝试执行
pnpm run reinstall - 切换手机热点进行依赖安装
- 配置国内镜像,在项目根目录创建
.npmrc文件:
# .npmrc
registry = https://registry.npmmirror.com/
缓存更新问题
项目配置默认缓存在 localStorage 内,版本更新后可能有些配置没改变。
解决方式: 每次更新代码时修改 package.json 内的 version 版本号。因为 localStorage 的 key 是根据版本号来的,更新后版本不同前面的配置会失效,重新登录即可。
修改配置文件问题
修改 .env 等环境文件以及 vite.config.ts 文件时,vite 会自动重启服务。自动重启有几率出现问题,请重新运行项目即可解决。
本地运行报错
由于 vite 在本地没有转换代码,且代码中用到了可选链等比较新的语法,本地开发需要使用版本较高的浏览器(Chrome 90+)。
页面切换后空白
开启路由切换动画,且页面组件存在多个根节点会导致此问题。
错误示例:
<template>
<!-- 注释也算一个节点 -->
<h1>text h1</h1>
<h2>text h2</h2>
</template>
正确示例:
<template>
<div>
<h1>text h1</h1>
<h2>text h2</h2>
</div>
</template>
提示:
- 如果想使用多个根标签,可以禁用路由切换动画
- template 下面的根注释节点也算一个节点
本地开发正常,打包后不行
排查是否使用了 ctx 变量:
// ❌ 错误用法 - ctx 未暴露在实例类型内,Vue 官方不推荐使用
import { getCurrentInstance } from 'vue';
getCurrentInstance().ctx.xxxx;
打包文件过大
- 使用精简版进行开发,完整版引用了较多库文件
- 开启 gzip,体积约为原先 1/3
- 可同时开启 brotli 压缩,比 gzip 更好
注意:
gzip_static模块需要 nginx 另外安装,默认未安装- 开启
brotli也需要 nginx 另外安装模块
运行错误 - 路径问题
如果出现类似以下错误,请检查项目全路径(包含所有父级路径)不能出现中文、日文、韩文:
[vite] Failed to resolve module import "ant-design-vue/dist/antd.css-vben-adminode_modulesant-design-vuedistantd.css"
控制台路由警告
如果页面能正常打开,以下警告可忽略:
[Vue Router warn]: No match found for location with path "xxxx"
后续 vue-router 可能会提供配置项来关闭警告。
启动报错 - Node.js 版本
出现以下错误时,检查 Node.js 版本是否符合要求:
TypeError: str.matchAll is not a function
nginx 部署 MIME 类型问题
部署到 nginx 后,可能出现以下错误:
Failed to load module script: Expected a JavaScript module script but the server responded with a MIME type of "application/octet-stream".
解决方式一: nginx 配置
http {
# 如果有此项配置需要注释掉
# include mime.types;
types {
application/javascript js mjs;
}
}
解决方式二: 修改 nginx 的 mime.types 文件,将 application/javascript js; 改为 application/javascript js mjs;
项目更新
无法像 npm 插件一样更新
项目是完整的项目模版,不是插件或安装包,无法像插件一样更新。需要根据业务需求二次开发,自行手动合并升级。
更新建议
项目采用 Monorepo 方式管理,核心代码如 packages/@core、packages/effects 已抽离。只要业务代码没有修改这部分代码,可以直接拉取最新代码合并。
建议: 关注仓库动态积极合并,不要长时间积累,否则合并冲突过多。
Git 更新流程
# 1. 添加公司 git 源地址
git remote add up gitUrl;
# 2. 提交代码到公司
git push up main
# 3. 同步公司代码
git pull up main
# 4. 同步开源最新代码
git pull origin main
移除百度统计代码
在对应应用的 index.html 文件中,删除以下代码:
<script>
var _hmt = _hmt || [];
(function () {
var hm = document.createElement('script');
hm.src = 'https://hm.baidu.com/hm.js?d20a01273820422b6aa2ee41b6c9414d';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(hm, s);
})();
</script>