Vue3 + Vite构建多页应用

本文涉及的产品
公共DNS(含HTTPDNS解析),每月1000万次HTTP解析
全局流量管理 GTM,标准版 1个月
云解析 DNS,旗舰版 1个月
简介: Vue3 + Vite构建多页应用

之前分享过在使用Vue-cli的时候怎么构建多页应用,如今随着Vite这样一个轻量级易用的构建工具的出现,越来越多的人也去尝试Vite了。在Vue-cli迁移到Vite的过程中,多多少少会有一些问题,多页应用的配置就是其中之一。

1,认识Vite项目中页面加载和根组件挂载过程

事实上,Vite项目中根组件加载过程和Vue-cli是差不多的,只不过目录结构有点小变化。

网络异常,图片无法展示
|

上述目录和文件:

  • 1.vscode项目配置
  • 2.nodejs项目依赖库文件,平时需要加入.gitignore
  • 3.公共文件夹
  • 4.源码文件夹
  • 4.1.存放静态资源例如图片、音频等等
  • 4.2.存放Vue组件
  • 4.3.Vue根组件,这个大家应该很熟悉
  • 4.4. 入口文件,大家也耳熟能详了
  1. 5. Git忽略文件
  2. 6. 主页面模板文件
  3. 7. 依赖配置文件,里面记录了依赖库
  4. 8. README文件
  5. 9. Vite项目的配置文件,和Vue-cli中的vue.config.js是一个作用

可见,对比起Vue-cli项目,最大的不同就是原先在public文件夹中的index.html,现在是在项目根目录了

(1) Vite项目中路径和网站访问路径的对应关系

首先我们要引入一个概念:根路径。在Vite工程中,默认情况下根路径就是我们的项目目录,src文件夹所在的那个目录(注意是所在),在Vite中用/表示根路径。因此在这里/开头的路径就是绝对路径。

网络异常,图片无法展示
|

通过在配置文件中指定root配置项的值可以自定义根路径的位置,不过平时可以不用修改。

那么在Vite中,我们的根组件又是如何被加载的呢?

在Vite工程中,当我们访问网站根路径的时候,事实上会访问到我们项目根路径上的index.html文件

没错,在Vite工程中,预览网页时访问网站的网址路径和我们工程路径是对应的

我们的Vite工程启动后,访问http://localhost:3000/,也就是访问我们的网址根路径的时候Vite就会去项目中寻找/index.html并返回,也就是说我们会访问到我们项目中的/index.html

同样地:

  • 访问http://localhost:3000/test/,Vite就会去项目目录中寻找/test/index.html并返回,即我们访问到的是/test/index.html文件
  • 访问http://localhost:3000/test/page/,Vite就会去项目目录中寻找/test/page/index.html并返回,即我们访问到的是/test/page/index.html文件

可见,我们访问网页路径的时候,和项目路径是一一对应的,这和大多数静态服务器一样。

同样地,在Vite中还有base配置项,这个配置项其实就和Vue-cli的publicPath是一个意思,就是开发或生产环境服务的公共基础路径,其默认值是/

通俗地讲,这个配置项表示我们外部访问的根路径是什么,也就是说我们在外部通过网址访问时访问什么路径,Vite就会去根路径寻找index.html

其默认值是/,也就是说正如上面讲的一样,我们访问网站根路径的时候,Vite就会让我们访问到项目根路径的index.html上面。

以此类推就很简单了,如果我们配置base值为/path,那当我们访问http://localhost:3000/path/的时候,Vite才会去项目根路径找到index.html并返回。

当我们配置base值为/path时,同样地:

  • 访问http://localhost:3000/path/test/,Vite就会去项目目录中寻找/test/index.html并返回,即我们访问到的是/test/index.html文件
  • 访问http://localhost:3000/path/test/page/,Vite就会去项目目录中寻找/test/page/index.html并返回,即我们访问到的是/test/page/index.html文件

(2) 根组件挂载

根组件的挂载和Vue-cli项目几乎一模一样,我们还是来看一下入口文件/src/main.js文件:

import { createApp } from'vue';
// 引入根组件importAppfrom'./App.vue';
// 创建根组件实例并挂载至html文件中createApp(App).mount('#app');

重点仍然在于createApp这个函数,先是引入组件模板,然后通过createApp函数,会返回一个提供应用上下文的应用实例,可以链式调用。

通俗地讲,先开始只是引入了Vue模板,但是仅仅引入模板,是不能将它和我们的html联系起来的。

通过createApp,我们才创建了一个可以供上下文使用的实例,也就是说只有这个函数,才能创建一个可以显示渲染的实例。

同样地,createApp函数后面也可以链式调用use函数引入其它插件。

最后通过mount函数,把这个实例内容,即App.vue文件的内容挂载至网页某个节点上,这样才能显示。

那为什么要挂载到idapp的节点上呢?可以打开/index.html文件看看:

网络异常,图片无法展示
|

可见当我们访问网页根路径时,我们就访问了index.html这个网页,这时main.js被执行,其中createApp函数执行,并将App.vue的内容挂载(填充)至这个htmlidappdiv

这里App.vue的内容如下:

网络异常,图片无法展示
|

访问网页,查看f12看看渲染结果:

网络异常,图片无法展示
|

可见通过main.js,把App.vue中的内容挂载到了html文件中idapp的节点下。

相信大家现在知道了Vite项目中,访问路径与项目路径的对应关系,以及一个页面的加载过程,知道了这些,配置出一个多页应用也是很简单的。

2,多页应用配置

同样地,多页应用中每一个页面也需要有它自己的html文件和入口js文件。

假设我这里要配置两个子页面,我们可以先在项目根目录下创建两个文件夹存放两个子页面的html文件和入口js文件。我这里创建两个文件夹pageonepagetwo,并将/index.html/src/main.js各复制一份到这两个文件夹:

网络异常,图片无法展示
|

每个子页面的入口js文件可以改名,但是html就不要改名了!保持index.html即可,否则访问时会导致找不到文件。

可见我这里子页面1对应的入口文件是/pageone/pageone.js,对应的html/pageone/index.html;子页面2对应的入口文件是/pagetwo/pagetwo.js,对应的html/pagetwo/index.html

然后我们在src文件夹中新建page文件夹专门用于存放所有子页面的vue根组件及其子组件文件,在page中给每个页面创建个文件夹,并在文件夹中创建每个页面的根组件文件,如下:

网络异常,图片无法展示
|

可见每个子页面的组件都放在/src/page中的一个文件夹中,便于管理。

上述子页面1和子页面2的根组件分别是PageOne.vuePageTwo.vue,两个文件内容如下:

网络异常,图片无法展示
|

不过这里为什么要把vue文件和入口文件与html文件分开放呢?放一起不更方便吗?

这里我觉得:

  • Vite项目中src目录基本上存放的绝大多数都是vue组件文件,两者分开会使得结构清晰
  • 若把html和入口文件也放在src中,访问子页面的时候路径会很长,打包后也很难对应

当然,这里也只是我的看法,大家可以根据自己的习惯进行组织,多页应用的配置的目录并非是死的,毕竟知道了页面加载的方式,我们也很容易配置多页应用了!

好了,现在修改每个页面的html文件和入口文件,这里先修改子页面1的html文件,打开/pageone/index.html文件,找到script标签,把里面的src属性值改成子页面1对应的入口文件路径,也就是说让子页面1的html文件链接上其入口文件:

网络异常,图片无法展示
|

注意这里src必须使用绝对路径!也就是/开头的路径,使用相对路径会导致无法加载。

然后修改子页面1的入口文件,打开/pageone/pageone.js文件,import组件的部分改成引入子页面1对应的Vue组件文件的路径:

网络异常,图片无法展示
|

好了,到此页面1就配置完成了!页面2也是同理。

然后就可以访问我们的多页应用了!

启动项目,访问http://localhost:3000/,如下:

网络异常,图片无法展示
|

访问http://localhost:3000/pageone/,如下:

网络异常,图片无法展示
|

访问http://localhost:3000/pagetwo/,如下:

网络异常,图片无法展示
|

注意在这里预览页面时,网址路径末尾必须以/结尾!否则也会导致找不到页面。

可见配置多页应用还是很简单的,如果仅仅是开发预览时配置多页应用,连配置文件都不用改。

3,多页应用打包

上述配置好多页应用之后,如果你这时执行打包构建命令,你会发现子页面文件并没有被包含到打包的结果中,因此我们还需要在配置文件中,配置一下打包解析,把每个子页面的html文件添加到打包解析中。

打开Vite配置文件vite.config.js,在其中进行打包解析配置。

先在配置文件中import一下resolve函数:

import { resolve } from'path';

然后加入以下配置内容:

build: {
rollupOptions: {
input: {
// 配置所有页面路径,使得所有页面都会被打包main: resolve(__dirname, 'index.html'),
pageone: resolve(__dirname, 'pageone/index.html'),
pagetwo: resolve(__dirname, 'pagetwo/index.html')
      }
   }
}

最终配置文件如下:

网络异常,图片无法展示
|

可见在上述的input中,配置一下每个页面的html文件解析路径即可!其中input对象里面,属性名可以自定义,属性值则是要解析的页面路径,通过resolve函数。

resolve函数的参数是填入多个路径,最终这个函数会把路径拼接起来。__dirname表示的是vite.config.js这个文件所在的路径。

在这里vite.config.js位于/,因此__dirname的值就是/,对于上述resolve(__dirname, 'pagetwo/index.html'),最终拼接出来的路径就是/pagetwo/index.html,这样就成功地找到了子页面2的html文件,打包的时候就会被包含。

需要注意的是,__dirname表示的是vite.config.js这个文件本身所在的路径而不是根路径! 因此即使你修改了配置项root为别的值,即你修改了根路径位置,这个__dirname的值仍然是vite.config.js这个文件所在的路径,这里需要注意一下。

再次执行打包命令npm run build,发现所有页面都被包含了:

网络异常,图片无法展示
|

同样地,如果配置了多页应用,就不能够把base配置为相对路径./了!否则会出现问题。

4,配置打包后页面文件到后端服务器

dist文件夹中的内容就可以放到后端服务器中去了!这里以Spring Boot为例,我们把dist文件夹中所有内容放到Spring Boot工程的src/main/resources/static目录下,即Spring Boot项目默认的静态资源目录下:

网络异常,图片无法展示
|

Spring Boot默认端口是8080,启动项目,访问http://127.0.0.1:8080/index.html,如下:

网络异常,图片无法展示
|

访问http://127.0.0.1:8080/pageone/index.html,如下:

网络异常,图片无法展示
|

访问http://127.0.0.1:8080/pagetwo/index.html,如下:

网络异常,图片无法展示
|

可见打包后配置到后端访问路径是和Vite开发预览时的是不一样的,这里注意即可,后端配置打包后的静态页面,访问路径就必须指定到具体的html文件上。

同样地,如果觉得访问路径太长或者不好看,也可以在Spring Boot中自定义Controller类进行自定义路由,这都是Spring Boot方面的内容了!这里就不再过多赘述,相信后端同学都能够信手拈来。

参考:

示例仓库地址



相关文章
|
6天前
|
敏捷开发 人工智能 JavaScript
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
Figma-Low-Code 是一个开源项目,能够直接将 Figma 设计转换为 Vue.js 应用程序,减少设计师与开发者之间的交接时间,支持低代码渲染和数据绑定。
27 3
Figma-Low-Code:快速将Figma设计转换为Vue.js应用,支持低代码渲染、数据绑定
|
2月前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
154 64
|
16天前
|
JavaScript API 数据处理
vue3使用pinia中的actions,需要调用接口的话
通过上述步骤,您可以在Vue 3中使用Pinia和actions来管理状态并调用API接口。Pinia的简洁设计使得状态管理和异步操作更加直观和易于维护。无论是安装配置、创建Store还是在组件中使用Store,都能轻松实现高效的状态管理和数据处理。
60 3
|
23小时前
|
JavaScript 前端开发
【Vue.js】监听器功能(EventListener)的实际应用【合集】
而此次问题的核心就在于,Vue实例化的时机过早,在其所依赖的DOM结构尚未完整构建完成时就已启动挂载流程,从而导致无法找到对应的DOM元素,最终致使计算器功能出现异常,输出框错误地显示“{{current}}”,并且按钮的交互功能也完全丧失响应。为了让代码结构更为清晰,便于后续的维护与管理工作,我打算把HTML文件中标签内的JavaScript代码迁移到外部的JS文件里,随后在HTML文件中对其进行引用。
18 8
|
2月前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
45 8
|
2月前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
41 1
|
2月前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
49 1
|
10天前
|
JavaScript
vue使用iconfont图标
vue使用iconfont图标
70 1
|
21天前
|
JavaScript 关系型数据库 MySQL
基于VUE的校园二手交易平台系统设计与实现毕业设计论文模板
基于Vue的校园二手交易平台是一款专为校园用户设计的在线交易系统,提供简洁高效、安全可靠的二手商品买卖环境。平台利用Vue框架的响应式数据绑定和组件化特性,实现用户友好的界面,方便商品浏览、发布与管理。该系统采用Node.js、MySQL及B/S架构,确保稳定性和多功能模块设计,涵盖管理员和用户功能模块,促进物品循环使用,降低开销,提升环保意识,助力绿色校园文化建设。
|
2月前
|
JavaScript 前端开发 开发者
vue学习第一章
欢迎来到我的博客!我是瑞雨溪,一名热爱前端的大一学生,专注于JavaScript与Vue,正向全栈进发。博客分享Vue学习心得、命令式与声明式编程对比、列表展示及计数器案例等。关注我,持续更新中!🎉🎉🎉
51 1
vue学习第一章
下一篇
开通oss服务