部署
路由和 vite 配置中都可以设置 base:
路由
import { createRouter, createWebHistory } from 'vue-router'
export default createRouter({
history: createWebHistory('/xxx/'),
// ...
})
vite 配置
import { defineConfig } from 'vite'
export default defineConfig({
base: '/vite/',
// ...
})
1 两处都不设置
data:image/s3,"s3://crabby-images/4e86e/4e86e3379e98befa183bb567f3c8b31441193037" alt="01"
1.1 开发环境
点击按钮可以正常切换页面,刷新也正常。
1.2 生产环境
任意位置
vue打包文件dist内的文件的存放路径 D:\study\vite-ts\dist
server {
listen 80;
server_name localhost;
location / {
root D:\study\vite-ts\dist;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
}
nginx html 内
vue打包文件dist内的文件的存放路径 D:\soft\nginx-1.22.0\html\vite
server {
listen 80;
server_name localhost;
location / {
root html/vite;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
}
2 vite 中设置 base
data:image/s3,"s3://crabby-images/7ea0d/7ea0d1ff3c71efc123153bca3582a7b739aab698" alt="02"
2.1 开发环境
点击按钮可以正常切换页面,但是不能刷新。
data:image/s3,"s3://crabby-images/cb1d7/cb1d78c1382244432a9b743ebef7cd86ae7e95de" alt="03"
可以发现 index.html 中所需的相关资源文件自动被加上了一个前缀。
刷新:
data:image/s3,"s3://crabby-images/c21bf/c21bfed3dad5497860773ab3575a10e372ff6dcd" alt="04"
2.2 生产环境
任意位置
vue打包文件dist内的文件的存放路径 D:\study\vite-ts\dist
server {
listen 80;
server_name localhost;
#用于匹配首页
location / {
root D:\study\vite-ts\dist;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
#用于匹配首页资源
location /vite {
alias D:\study\vite-ts\dist;
}
}
nginx html 内
vue打包文件dist内的文件的存放路径 D:\soft\nginx-1.22.0\html\vite
server {
listen 80;
server_name localhost;
location / {
root html/vite;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
location /vite {
alias html/vite;
}
}
3 路由设置 base
data:image/s3,"s3://crabby-images/b7cdb/b7cdb49f0be7e216c6bd35e2da56b10d8511f172" alt="05"
3.1 开发环境
点击按钮可以正常切换页面,刷新也正常。
data:image/s3,"s3://crabby-images/c5201/c5201159e981efdd24e688fce5524fe0555deac6" alt="06"
data:image/s3,"s3://crabby-images/f7e9b/f7e9b1d60657bc46f07b8a969d628beb212ac10a" alt="07"
3.2 生产环境
任意位置
server {
listen 80;
server_name localhost;
location / {
root D:\study\vite-ts\dist;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
}
nginx html 内
server {
listen 80;
server_name localhost;
location / {
root html/vite;
index index.html index.htm;
try_files $uri $uri/ /index.html;
}
}
4 两处都设置
data:image/s3,"s3://crabby-images/9b85c/9b85cfe96253ec81591c440d3a09773dc841c252" alt="08"
4.1 开发环境
点击按钮可以正常切换页面,刷新也正常。
data:image/s3,"s3://crabby-images/dacef/dacef237bf7064135de851bf11b0109538ab0698" alt="09"
4.2 生产环境
任意位置
vue打包文件dist内的文件的存放路径 D:\study\vite-ts\dist
。
server {
listen 80;
server_name localhost;
location / {
root D:\study\vite-ts\dist;
index index.html index.htm;
}
location /vite {
alias D:\study\vite-ts\dist;
try_files $uri $uri/ /index.html;
}
}
nginx html 内
vue打包文件dist内的文件的存放路径 D:\soft\nginx-1.22.0\html\vite
。
server {
listen 80;
server_name localhost;
location / {
root html/vite;
index index.html index.htm;
}
location /vite {
alias html/vite;
try_files $uri $uri/ /index.html;
}
}
5 两处都设置,base 不相同
data:image/s3,"s3://crabby-images/129b9/129b9fe316c02ba2fab287599e51ec87bb24e656" alt="10"
5.1 开发环境
浏览器输入localhost:3000,显示如下,点击按钮可以正常切换页面,但是不能刷新
localhost:3000 -> localhost:3000/a -> localhost:3000/b/a
data:image/s3,"s3://crabby-images/d9719/d9719f61667ebe222a54d1af92a405f063deb3bd" alt="11"
data:image/s3,"s3://crabby-images/7e577/7e5770a81fb555289355d1d2f3610f78d7c29a8f" alt="12"
5.2 生产环境
任意位置
vue打包文件dist内的文件的存放路径 D:\study\vite-ts\dist
server {
listen 80;
server_name localhost;
# 返回 index.html
location / {
root D:\study\vite-ts\dist;
index index.html index.htm;
}
# 使 index.html 所需资源能被正确引用
location /a {
alias D:\study\vite-ts\dist;
}
#配和路由history模式、解决不能刷新的问题
location /b {
try_files $uri $uri/ /index.html;
}
}
nginx html 内
vue打包文件dist内的文件的存放路径 D:\soft\nginx-1.22.0\html\c
server {
listen 80;
server_name localhost;
# 返回 index.html
location / {
root html/c;
index index.html index.htm;
}
# 使 index.html 所需资源能被正确引用
location /a {
alias html/c;
}
#配和路由history模式、解决不能刷新的问题
location /b {
try_files $uri $uri/ /index.html;
}
}
当 base: ‘/a/’,碰到 history: createWebHistory() (情况2)或者 当 base: ‘/a’,碰到 history: createWebHistory()(情况5)开发环境下会出现不能刷新的问题。
实际情况一般使用情况 1、4,有时也可以根据情况使用 2、3。
设置 base: ‘/vite/’ 的作用:
给 index.html 中所引用的资源路径添加前缀。
设置 history: createWebHistory(‘/vite/’) 的作用:
给所有路由 path 添加一个前缀。
部署到根目录和非根目录的区别:
部署到根目录
location / {
index index.html index.htm
}
部署到非根目录
location /sub {
index index.html index.htm
}