vue3实现多页面打包容易,关键是如何实现本地的开发和调试?我们接下来解决如下几个问题:
1 多页面项目的项目结构是怎样的?
--public
--src
---App.vue
---main.js
---page1. +
---App.vue
---main.js
----home.vue
----list.vue
---page2. +
---App.vue
---main.js
----home.vue
----list.vue
vite.config.js
package.json
page1.html. +
page2.html. +
这是我们配置的最原始的一个结构,如图,带+的是新增的文件(文件夹)特别注意新增的page1.html和page2.html,这两个模版文件是一定不能忘记的。同时要注意script中引用main.js文件路径的修改,如图
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<link rel="icon" type="image/svg+xml" href="/vite.svg" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Vite + Vue</title>
</head>
<body>
<div id="app"></div>
<script type="module" src="/src/page2/main.js"></script>
</body>
</html>
但是仅仅只是这样还是不够的,我们要打包成不同的项目,那需要在对vite.config.js做一些更改
import { defineConfig } from 'vite'
import vue from '@vitejs/plugin-vue'
import {resolve} from "path"
// https://vitejs.dev/config/
export default defineConfig({
plugins: [vue()],
server:{
hmr:true
},
build:{
rollupOptions:{
input:{
index:resolve(__dirname,'index.html'),
page1:resolve(__dirname,"/page1.html"),
page2:resolve(__dirname,"/page2.html")
},
output:{
chunkFileNames:"js/[name]-[hash].js",
assetFileNames:"[ext]/[name]-[hash].[ext]"
}
}
}
})
我们需要对rollipOption选项的input和output做多入口和出口的设置。到这一步。我们 打包以后就可以正常生成对应的文件了。我们看一看结果:
同时我们通过http://localhost:5173/page1.html就能正常访问page1,和page2了,展示的内容分别是page1项目和page2项目的app.vue的内容。但是我们的page1和page2项目可不止一个app.vue,我们要通过路由配置不同的路由访问不同的页面。接下来我们需要配置来看路由了,不过在此之前我们要先改造下我们的项目目录结构
仔细观察。我们在page1和page2这两个项目下分别新增了一个views文件夹,用来存放页面,同时新增了一个home和list页面,用来测试。然后我们再新增我们的路由文件,注意 路径和组件的引用
//src下新建router文件夹
//main.js 主入口的main.js
import { createApp } from 'vue'
import './style.css'
import App from './App.vue'
import router from "./router/index". +
createApp(App).use(router).mount('#app')
--------router.js----------------
import { createRouter, createWebHistory ,createWebHashHistory} from 'vue-router'
const router = createRouter({
history: import.meta.env.DEV ? createWebHashHistory() : createWebHistory(),
routes: [
{
path: '/',
name: 'home',
component: ()=>import("../pages/home.vue")
},
{
path: '/list',
name: 'list',
component: ()=>import("../pages/list.vue")
},
{
path: '/page1/home',
name: 'page1Home',
component: ()=>import("../page1/views/home.vue")
},
{
path: '/page1/list',
name: 'page1List',
component: ()=>import("../page1/views/list.vue")
},
{
path: '/page2/home',
name: 'page2Home',
component: ()=>import("../page2/views/home.vue")
},
{
path: '/page2/list',
name: 'page2List',
component: ()=>import("../page2/views/list.vue")
}
]
})
export default router
到此为止。我们通过页面访问page1下的home,则只需要输入地址http://localhost:5173/#/page1/home这样我们就能正常访问了。如下图:
其他的多页面地址访问同理