vue3+vite+nginx打包

在开发环境下,已经可以正常地运行一个有增删改查功能的页面了,但如何把它发布到运行服务器呢?仍有许多的问题需要探索。

网上很多文章给了很大的帮助,但总是没有说明原理,对于像我这样的初学者来说,不知其所以然,也就不能根据自己的情况加以变通,现在总算是基本走通了,就总结一下,供初学者参考:

1.在开发环境下,通过npm run dev就能启动网页服务,通过配置vite.config.ts就能实现ajax跨域访问,这些都正常了,但在实际部署时,总要把它部署到一个服务器才行。 

服务器:一般是用nginx,iis应该也是可以的,但没有深入测试,总之是要先运行npm run build来编译项目,将typescript转为javascript,生成的文件在项目目录\dist目录下。如果不编译成javascript,nginx是不能直接运行typescript的(或者需要额外的配置)。

2.在编译后,将dist目录下的文件复制到nginx目录下,再配置了nginx\conf\nginx.conf,仍会有很多错误,可以参考这篇文章:

vite+vue3打包后部署nginx Failed to load module script,空白页,404,反向代理等问题。_vite加上nginx进行反向代理-优快云博客

其中我最关心的是ajax的跨域问题,其实要解决的核心问题就是2个:

1、写在页面里的ajax url,如何在打包后,变成正确的地址?

2、访问地址正确了,nginx如何把它映射到后端api接口?

对于问题1:

网上文章很多,其实就是要定义一个公共变量,在ajax地址中拼接这个公共变量,且这个变量要分成开发环境和部署环境2个。

这个如果自己写一套机制也可以,或者就采用现成的vite的框架,建立2个配置文件:

vite在开发环境或部署环境,会分别采用这2个文件中的一个。

这个是开发环境下的文件,里面是开发环境的ajax地址。

一般网上都是用http://localhost:xxxx/ajax,我有意把ajax写成vue,以便观察后续配置哪些地方要做相应关联:

这个是vite.config.ts的配置,上面写的是vue,这里也要写vue

项目target:'http://localhost:8200/'是后端api接口地址,用于接收ajax请求

这个是部署环境的地址,

8090是在nginx配置文件配置的:

注意看红框中的,它是nginx配置的反向代理,就是通过这个来找到后台ajax服务的。

总结:在开发环境下是通过vite.config.ts来实现ajax跨域;而部署环境下是通过nginx的反向代理来实现的。这样就解决了问题2。

再接着说定义的2个变量如何使用?网上文章一般是创建一个request文件,在里面再定义一个service或其他什么名称的axios封装类,这个类的baseURL引用之前2个配置文件中定义的VITE_API_BASE_URL,这无疑是非常好的一个构想,但对于我来说,代码要重构了,之前的访问方式都是直接写成

axios.post(  '/api/values/Options',null).then((res)=>{

......这样的,而且我只是想先测通,就不做大改了,直接引用这个变量:

然后再运行npm run build,部署,数据可以正常获取

其它的坑:

1.修改nginx后,不生效,甚至关闭后仍然可以打开网页。这个是因为用start_server.bat启动,它的nginx.exe在关闭后,进程却还在后台运行。需要手工在进程管理器里关掉。我是直接重启服务器的。建议改成start nginx命令,它关闭命令窗口后就真的关闭进程了。

2.直接输入地址不能访问,可以通过以下配置来解决

Vue3是一种流行的JavaScript框架,它提供了一种简洁、高效的方式来构建用户界面。TypeScript是一种静态类型检查的JavaScript超集,可以增强代码的可读性和可维护性。Vite是一个基于ES模块的构建工具,用于快速构建现代化的Web应用程序。 要将Vue3 + TypeScript + Vite项目部署到Nginx服务器上,可以按照以下步骤进行操作: 1. 构建项目:在本地开发环境中,使用Vite构建工具将Vue3 + TypeScript项目打包成静态文件。在项目根目录下运行以下命令: ``` npm run build ``` 这将生成一个`dist`目录,其中包含了构建后的静态文件。 2. 配置Nginx:在Nginx服务器上创建一个新的站点配置文件,例如`myapp.conf`。可以使用以下命令在`/etc/nginx/conf.d/`目录下创建该文件: ``` sudo nano /etc/nginx/conf.d/myapp.conf ``` 在配置文件中添加以下内容: ``` server { listen 80; server_name yourdomain.com; # 替换为你的域名 root /path/to/your/project/dist; # 替换为你的项目dist目录的路径 index index.html; location / { try_files $uri $uri/ /index.html; } } ``` 确保将`yourdomain.com`替换为你的域名,并将`/path/to/your/project/dist`替换为你的项目`dist`目录的实际路径。 3. 重启Nginx:保存并关闭配置文件后,使用以下命令重启Nginx服务器以使配置生效: ``` sudo service nginx restart ``` 现在,你的Vue3 + TypeScript + Vite项目应该已经成功部署到Nginx服务器上了。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值