上午已经把Nginx安装好,现在就进行部署。
打包项目
npm run build
data:image/s3,"s3://crabby-images/1e756/1e756034507680ce3764534181fd107bbd1a0fe0" alt=""
然后会在项目根目录中生成
dist
文件夹
Nginx配置
打开Nginx的配置文件 E:\nginx-1.15.12\conf\nginx.conf
data:image/s3,"s3://crabby-images/ec66c/ec66c1f70d5a189e194a27b6815a26e1c5a6d275" alt=""
然后启动Nginx,访问http://localhost,项目正常运行起来了。
data:image/s3,"s3://crabby-images/510ac/510acf3b9bdba5b6e6c449f69eb7020ed9493eef" alt=""
遇到的问题
项目看似已经正常运行了,能正常跳转,但是在我刷新页面的时候出错了。
data:image/s3,"s3://crabby-images/a3b82/a3b820fc16a1f79bb8f66c701aa9b1eb8c48af02" alt=""
解决方式一:
把vue-router
的mode
修改为hash
,如果不配置默认就是hash
,我是修改过所以要改回来。
mode: "hash",
data:image/s3,"s3://crabby-images/55fd0/55fd0fe8a31f43444b3910ad25770c034dc5948e" alt=""
··
然后重新打包就可以了,但是这种模式会在
Url
上面出现非常丑的#
,如果不介意就这样就可以了,我是受不了。
解决方式二:
mode: "history",
我就非要把 #
号搞掉,那么可以在Nginx里面配置一句话.
try_files $uri $uri/ /index.html;
data:image/s3,"s3://crabby-images/3ff12/3ff12a20821c86c05dfd06ae73525da9100fa403" alt=""
至于这句话是啥意思可以百度查查,我就简单的理解为
rewrite
解决方式三 - 网上看到的没有测试过,只是做个记录
匹配errpr_page
location /{
root /data/nginx/html;
index index.html index.htm;
error_page 404 /index.html;
}
暂时我就只遇到这点问题,遇到其他问题在记录。
网友评论