Vue History模式的Nginx配置

前言

  • vue-router有两种模式,hash模式和history模式。
  • 直观区别:hash模式url带#号,history模式不带#号。
  • hash模式:由于hash值变化不会导致游览器向服务器发出请求,所以可以实现前端路由,无需额外的配置。
  • history模式:history模式不仅可以在url里放参数,还可以将数据存放在一个特定的对象中。

history模式存在问题

  • hash兼容IE8以上,history兼容IE10以上;
  • history模式需要后端配合将所有访问都指向index.html,否则用户刷新页面,会导致404错误。

history模式下的Nginx配置

bash 复制代码
    server {
        listen 9023; # 端口号
        index index.html; #通过index来访问index.html
        client_max_body_size 1024m;
        root /vdd/ynk/gicweb/pcweb;  #静态资源的位置
        try_files $uri $uri/ /pro-gic-web/index.html; # history模式配置
   
        #登录接口
        location /login {
            proxy_set_header Host $host; # 传递域名
            proxy_set_header X-Real-Ip $remote_addr; # 传递ip
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Scheme $scheme; # 传递协议        
            proxy_pass http://172.16.22.60:31021;
        }
}

try_files注意事项,

  • /pro-gic-web/index.html,如果有目录或前端,index.html要加上目录或前缀,这里对应的是静态资源地址,否则nginx找不到对应静态资源。
  • 如果没有前缀,资源在要目录下,则不需要前缀,直接配置主入口文件,即index.html
相关推荐
前端Hardy16 小时前
谁还没⽤过shadcn/ui?114k+星标,不装NPM包,前端组件自由终于实现了
前端·javascript·vue.js
morestrive16 小时前
基于 fabric.js 实现浏览器端矢量 PDF 导出
前端·github
Bolt17 小时前
用 pnpm 11 省掉项目里的 .nvmrc 与 .npmrc
前端·npm·node.js
猪猪聪明_V17 小时前
前端码农的本地项目启动器
前端·javascript
时光不负努力17 小时前
每天一个高级前端知识 - Day 21
前端
暗不需求17 小时前
前端性能优化 防抖与节流完全指南:从原理到最佳实践
前端·javascript·面试
@大迁世界17 小时前
45.什么是内联条件表达式(inline conditional expressions)?在事件处理里怎么用?
开发语言·前端·javascript·react.js·ecmascript
一颗趴菜18 小时前
微信小程序如何去下载PDF呢
前端·javascript
KaMeidebaby18 小时前
卡梅德生物技术快报|细菌 FISH 实验 + 流式细胞术:尿路感染活菌快速定量系统实现与数据验证
前端·数据库·其他·百度·新浪微博
昆曲之源_娄江河畔18 小时前
DBGridEh Footer的使用
前端·数据库·delphi·dbgrideh