Vue CLI 脚手架创建项目流程详解 (2)

更新 CLI 脚手架

确保你安装的是最新版本的 Vue CLI,以支持最新的特性及改进。你可以通过以下命令全局安装或更新 Vue CLI:

shell 复制代码
npm install -g @vue/cli

创建 Vue 3.x 项目

  1. 启动创建向导

    使用 vue create 命令来开始创建一个新的 Vue 项目:

    shell 复制代码
    vue create vue-project
  2. 选择手动配置

    由于要使用 TypeScript ,所以需要选择最后一个选项来进行自定义搭配,通过键盘的上下箭头进行切换选择:

  3. 选择特性

    根据提示选择你想要包含的功能,如 Babel、TypeScript、Router 等等。对于一个完整的 Vue 3 + TypeScript 项目,你可能希望选中以下选项:

    • Babel
    • TypeScript
    • Router
    • CSS Pre-processors
    • Linter / Formatter
  4. Vue 版本选择

    选择要使用的 Vue.js 版本。由于我们创建的是 Vue 3 项目,请选择 3.x

  5. Class 组件语法

    对于 Vue 3,推荐使用 Composition API 而不是 Class 语法,因此这里选择 n

  6. Babel 和 TypeScript 的搭配

    如果你需要支持现代模式和 JSX,则应选择 y 来启用 Babel。

  7. 路由模式

    对于生产环境中的历史记录模式(history mode),如果服务器端已经正确设置以处理所有路径回退到 index.html,则可以选择 y。否则,如果你不打算立即部署或不确定服务器配置,可以选择哈希模式(hash mode)n

  8. CSS 预处理器

    选择你喜欢的 CSS 预处理器。Sass/SCSS 是一个流行的选择,并且与许多 UI 库兼容。

  9. Lint 规则

    选择合适的 ESLint 配置,比如 ESLint + Prettier 是一种常见的组合,它不仅提供代码风格检查还提供了自动格式化功能。

  10. Lint 检查时机

    决定是否在保存文件时进行 Lint 检查或仅在提交代码时检查。这里通常选择 Lint on save

  11. 配置文件位置

    选择将配置存储在单独的文件中还是合并到 package.json 中。独立文件更易于管理和共享。

  12. 保存为预设

    为了未来更快地创建类似项目,可以将当前配置保存为一个预设。

解决 history 模式下的 404 问题

当使用 Vue Router 的 history 模式时,直接访问子路径可能会导致 404 错误。解决方法取决于你的部署环境:

  • 开发阶段 :可以通过配置 Webpack Dev Server 的 historyApiFallback 选项来避免这个问题。

    javascript 复制代码
    devServer: {
      historyApiFallback: true,
    }
  • 测试或本地打包后预览 :使用 serve 工具并加上 -s 参数来重定向所有未找到的请求至 index.html

    json 复制代码
    "scripts": {
      "preview": "serve ./dist -l 4000 -s",
    }
  • 线上环境 (Node.js) :安装适当的中间件如 connect-history-api-fallback

  • 线上环境 (Nginx) :调整 Nginx 配置以确保所有未知路径都指向 index.html

    nginx 复制代码
    location / {
      try_files $uri $uri/ /index.html;
    }
打印 Webpack 配置

如果你想查看 Vue CLI 底层生成的 Webpack 配置,可以运行如下命令将其输出到指定文件:

shell 复制代码
npx vue-cli-service inspect > config/webpack.config.js

这可以帮助你理解构建过程中的配置细节,尤其是在遇到构建相关的问题时非常有用。

总结

通过上述步骤,你应该能够顺利创建并配置一个基于 Vue 3 和 TypeScript 的新项目。每个步骤都旨在帮助你根据项目的具体需求定制最合适的开发环境。

相关推荐
鱼樱前端43 分钟前
uni-app快速入门章法(二)
前端·uni-app
silent_missile1 小时前
vue3父组件和子组件之间传递数据
前端·javascript·vue.js
克里斯蒂亚诺更新2 小时前
微信小程序app.js中每30秒调用一次wx.getLocation
javascript·微信小程序·小程序
IT_陈寒2 小时前
Vue 3.4 实战:这7个Composition API技巧让我的开发效率飙升50%
前端·人工智能·后端
鄃鳕2 小时前
C++坑系列,C++ std::atomic 拷贝构造函数问题分析与解决方案
java·javascript·c++
JIngJaneIL3 小时前
图书馆自习室|基于SSM的图书馆自习室座位预约小程序设计与实现(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·图书馆自习室
少年阿闯~~3 小时前
HTML——1px问题
前端·html
Never_Satisfied3 小时前
在JavaScript / HTML中,实现`<iframe>` 自适应高度
开发语言·javascript·html
Mike_jia3 小时前
SafeLine:自托管WAF颠覆者!一键部署守护Web安全的雷池防线
前端
brzhang4 小时前
把网页的“好句子”都装进侧边栏:我做了个叫 Markbox 的收藏器,开源!
前端·后端·架构