使用vite创建的vue3项目,如何配置路由前缀,及nginx如何配置
- vite.config.js
- 配置base
export default defineConfig({
base: "/functionalBudget", //浏览器路由前缀 /functionalBudget
plugins: [
vue(),
AutoImport({
resolvers: [ElementPlusResolver()],
}),
Components({
resolvers: [ElementPlusResolver()],
}),
],
resolve: {
alias: {
"@": resolve(__dirname, "src"), //设置`@`指定`src`目录
assets: resolve(__dirname, "./src/assets"),
},
},
css: {
//预处理器选项
preprocessorOptions: {
scss: {
additionalData: `@import "assets/style/main.scss";`,
},
},
},
define: {},
server: {
host: true,
port: 5713,
open: false,
cors: true,
//配置代理
proxy: {
"/nmis": {
target: "http://localhost:8000",
changeOrigin: true,
rewrite: (path) => path.replace(/^\/nmis/, "/xg/api/nmis"),
},
},
},
});
- router/index.js
- history模式,通过createWebHistory传入前缀
import { createRouter, createWebHistory } from "vue-router";
const router = createRouter({
history: createWebHistory("/functionalBudget/"), // history模式
routes: [
{
path: "/",
component: () => import("@/components/HelloWorld.vue"),
},
{
path: "/luckysheet",
component: () => import("@/views/luckysheet/index.vue"),
},
{
path: "/template",
component: () => import("@/views/luckysheet/template.vue"),
},
{
path: "/401",
component: () => import("@/views/features/401.vue"),
},
{
path: "/404",
component: () => import("@/views/features/404.vue"),
},
],
});
export default router;
- ngninx的配置
- 修改nginx.conf
#user nobody;
worker_processes 1;
#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;
#pid logs/nginx.pid;
events {
worker_connections 1024;
}
http {
include mime.types;
default_type application/octet-stream;
#log_format main '$remote_addr - $remote_user [$time_local] "$request" '
# '$status $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';
#access_log logs/access.log main;
sendfile on;
#tcp_nopush on;
#keepalive_timeout 0;
keepalive_timeout 65;
#gzip on;
server {
listen 81;
server_name localhost;
#charset koi8-r;
#access_log logs/host.access.log main;
# location / {
# root html;
# index index.html index.htm;
# }
# 配置url路径匹配关系,定义标示,区分多个服务
location /functionalBudget {
# 指定静态文件目录的根路径
alias D:/cobot1/vite_vue3_luckysheet/lucky/my-vue-app/nginx-1.24.0/html/dist;
# 指定在请求的URL中未指定文件名时要使用的默认文件名
index index.html index.htm;
# 优先根据浏览器输入的文件路径进行查找,如果找不到重定向index.html文件
try_files $uri $uri/ /functionalBudget/index.html;
}
location / {
rewrite ^/$ /functionalBudget/ redirect;
try_files $uri $uri/ /index.html;
}
#error_page 404 /404.html;
# redirect server error pages to the static page /50x.html
#
error_page 500 502 503 504 /50x.html;
location = /50x.html {
root html;
}
# proxy the PHP scripts to Apache listening on 127.0.0.1:80
#
#location ~ \.php$ {
# proxy_pass http://127.0.0.1;
#}
# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
#
#location ~ \.php$ {
# root html;
# fastcgi_pass 127.0.0.1:9000;
# fastcgi_index index.php;
# fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
# include fastcgi_params;
#}
# deny access to .htaccess files, if Apache's document root
# concurs with nginx's one
#
#location ~ /\.ht {
# deny all;
#}
}
# another virtual host using mix of IP-, name-, and port-based configuration
#
#server {
# listen 8000;
# listen somename:8080;
# server_name somename alias another.alias;
# location / {
# root html;
# index index.html index.htm;
# }
#}
# HTTPS server
#
#server {
# listen 443 ssl;
# server_name localhost;
# ssl_certificate cert.pem;
# ssl_certificate_key cert.key;
# ssl_session_cache shared:SSL:1m;
# ssl_session_timeout 5m;
# ssl_ciphers HIGH:!aNULL:!MD5;
# ssl_prefer_server_ciphers on;
# location / {
# root html;
# index index.html index.htm;
# }
#}
}
-
打包文件放置路径:
-
浏览器访问: