如何使用Vite构建vue项目

打印 上一主题 下一主题

主题 554|帖子 554|积分 1662

目录

1.查抄node.js和npm/pnpm的安装
2.构建一个 Vite + Vue 项目
2.1 执行提示的命令
3.使用HBuilderX导入项目
4.使用 Vite 和 Vue 3 构建 SPA
4.1项目布局
4.2 增加路由
4.3 安装组件Element Plus
4.4 配置路由
4.4.1 创建两个文件为后续跳转做准备
4.4.2 创建路由:router/index.js文件中,声明路由表(注册所有vue文件)
4.4.3 改造App.vue,设定RouterView
4.4.4 在整个项目中使用路由,在main.js中注册
4.4.5 再次运行 pnpm run dev
5.总结
5.1 App.vue vue文件特点
5.2
   的作用  
  5.3 Vue Router和Element Plus
  5.4 Vue框架开发单页面开发SPA
  
  
  1.查抄node.js和npm/pnpm的安装

这里我使用的是pnpm
  1. node -v
  2. pnpm -v
复制代码



2.构建一个 Vite + Vue 项目

此中cxr_kfc是我的项目名称
运行必要指定工作空间,在自己的目录下打开

  1. pnpm create vite cxr_kfc --template vue
复制代码
运行成功



2.1 执行提示的命令

会在项目文件中增加一个文件,不要乱动,否则可能报错

运行成功





3.使用HBuilderX导入项目




4.使用 Vite 和 Vue 3 构建 SPA

4.1项目布局

Vite 会自动创建一个根本的项目布局,包括 src 目录下的组件、路由和状态管理等文件。


  • src: 包含源代码

    • App.vue: 根组件
    • main.js: 应用步伐入口
    • router: Vue Router 配置
    • store: 状态管理(如使用 Pinia,这里我暂时没有用到)

4.2 增加路由

可以轻松地在单页面应用(SPA)中实现页面间的导航和视图的动态加载
  1. pnpm add vue-router@4
复制代码
路由安装成功

4.3 安装组件Element Plus

安装成功

4.4 配置路由

4.4.1 创建两个文件为后续跳转做准备

先在src创建一个目录pages,在目录中创建两个vue文件

再两个文件中放入测试数据



4.4.2 创建路由:router/index.js文件中,声明路由表(注册所有vue文件)

在src中创建一个router目录,在router目录中创建一个index.js文件,在文件中声明路由,文件中代码如下:
  1. import { createWebHashHistory, createRouter } from 'vue-router'
  2. // 注册自定义的vue文件
  3. import Order from '../pages/Order.vue'
  4. import Billing from '../pages/Billing.vue'
  5. // 路由表
  6. const routes = [
  7.   { path: '/', component: Order },
  8.   { path: '/Billing', component: Billing },
  9. ]
  10. // 创建路由对象
  11. const router = createRouter({
  12.   history: createWebHashHistory(),
  13.   routes,
  14. })
  15. //声明:导出
  16. export default router
复制代码
此中,路由表中


  • path: 这是指定的 URL 路径。当用户在浏览器地址栏中输入这个路径大概通过 Vue Router 的 <router-link> 或编程式导航 (this.$router.push()) 导航到这个路径时,对应的组件将会被渲染。
  • component: 这是与指定路径关联的 Vue 组件。当路径匹配时,这个组件将被加载并显示在 <router-view> 占位符的位置上。
4.4.3 改造App.vue,设定RouterView

将App.vue文件中的内容替换:
  1. <template>
  2.         <router-link to="/">点餐</router-link>
  3.         <router-link to="/billing">结账</router-link>
  4.        
  5.         <router-view></router-view>
  6. </template>
复制代码
4.4.4 在整个项目中使用路由,在main.js中注册

  1. import { createApp } from 'vue'
  2. import './style.css'
  3. import App from './App.vue'
  4. //引入路由index.js,导入js文件
  5. import router from './router/index.js'
  6. const app = createApp(App)
  7. app.use(router)
  8. app.mount('#app')
复制代码
4.4.5 再次运行 pnpm run dev

成功,实现跳转



5.美化页面



6.总结

6.1 App.vue vue文件特点

由3部分组成:template 写html代码、script js脚本vue3+ setup语法方式、style css样式,scoped限定只在本片段中见效,每个组件都应该有一个清晰的职责和数据流,
没有序次关系


6.2<div id="app">的作用

<div id="app"></div> 这个元素是 Vue 实例挂载点的标识。
当你启动项目并在浏览器中打开它时,Vue 会查找这个特定的 DOM 元素,并将其作为 Vue 实例的挂载点。


createApp(App) 创建了一个 Vue 应用步伐实例,此中 App 是你的应用步伐的根组件,通常定义在 App.vue 文件中。.mount('#app') 方法则将这个应用步伐实例挂载到页面上带有 id="app" 的 DOM 元素上。

所以我们不会直接修改 index.html 文件中的 #app 元素内容,而是通过 Vue 组件和模板语法来动态生成这部分内容。

6.3 Vue Router和Element Plus

Vue Router 是 Vue 官方的客户端路由解决方案。
客户端路由的作用是在单页应用 (SPA) 中将浏览器的 URL 和用户看到的内容绑定起来。当用户在应用中浏览差别页面时,URL 会随之更新,但页面不必要从服务器重新加载。
Vue Router 基于 Vue 的组件体系构建,你可以通过配置路由来告诉 Vue Router 为每个 URL 路径显示哪些组件。
Element Plus 是 Element UI 的升级版,是一个基于 Vue 3 的现代化 UI 组件库,它提供了一系列丰富且风格统一的组件,帮助开发者快速构建美观、响应式的界面。Element Plus 遵照了 Material Design 和 iOS 的设计原则,适用于构建桌面和移动设备上的应用步伐。

6.4 Vue框架开发单页面开发SPA

它和传统开发不一样的(asp/jsp/php/h5 多页面)
怎么去把其他内容(home首页、about关于…)怎么存储,显现它通过路由工具Vue-router进行跳转
RouterLink 类似a标签,链接
RouterView 类似显现的地方,它可以接收路由跳转

6.5 为什么使用Vite

1.实际问题
基于 JavaScript 开发的工具就会开始遇到性能瓶颈:通常必要很长时间(乃至是几分钟!)才能启动开发服务器,即使使用模块热替换(HMR),文件修改后的效果也必要几秒钟才能在浏览器中反映出来。云云循环往复,痴钝的反馈会极大地影响开发者的开发效率和幸福感。
Vite 旨在利用生态体系中的新希望解决上述问题:浏览器开始原生支持 ES 模块,且越来越多 JavaScript 工具使用编译型语言编写。
2.快速的服务器启动
Vite 通过在一开始将应用中的模块区分为 依靠 和 源码 两类,改进了开发服务器启动时间。
Vite 将会使用 esbuild 预构建依靠。esbuild 使用 Go 编写,而且比以 JavaScript 编写的打包器预构建依靠快 10-100 倍。
Vite 以 原生 ESM 方式提供源码。这实际上是让浏览器接管了打包步伐的部分工作:Vite 只必要在浏览器请求源码时进行转换并按需提供源码。根据情景动态导入代码,即只在当前屏幕上实际使用时才会被处置惩罚。
3.快速更新
在 Vite 中,HMR 是在原生 ESM 上执行的。当编辑一个文件时,Vite 只必要准确地使已编辑的模块与其最近的 HMR 边界之间的链失活[1](大多数时间只是模块本身),使得无论应用巨细如何,HMR 始终能保持快速更新。
要确保开发服务器和生产情况构建之间的最优输出和行为同等并不容易。所以 Vite 附带了一套 构建优化 的 构建命令,开箱即用。

6.6vite项目标布局和加载的原理

Vite 项目布局简便,主要包括 src/ 存放源代码,public/ 存放静态资源,index.html 作为入口文件。加载原理利用浏览器原生 ESM 支持,按需编译模块,结合高效 HMR 实现快速开发反馈,预构建时优化资源,提升生产情况性能。

6.7Node.js/npm/pnpm

Node.js

Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行情况,允许开发者使用 JavaScript 开发服务器端应用步伐。它接纳了事件驱动、非壅闭 I/O 模子,使其轻量且高效,非常适合运行数据密集型实时应用。Node.js 支持广泛的模块和包,可以通过 npm/pnpm进行安装和管理。
npm

npm 是随 Node.js 一起提供的包管理器,用于管理和安装 Node.js 应用步伐的依靠包。npm 提供了一个庞大的在线仓库,包含数百万个开源软件包,开发者可以轻松搜刮、下载和集成这些包到自己的项目中。npm 还提供了本地包管理功能,帮助开发者管理项目依靠和版本控制。
pnpm

pnpm 是另一个用于 Node.js 的包管理器,它旨在解决 npm 和 yarn 在性能和磁盘空间使用上的问题。pnpm 使用了链接的工作区概念,通过硬链接来减少重复文件的存储,从而节流磁盘空间。同时,它提供了并行安装的能力,加速了依靠的安装过程。pnpm 也支持最新版的 JavaScript 和 TypeScript 语法特性,以及现代的模块体系。









免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

李优秀

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表