react build 后打包发布总结

一,部署在apache web服务器上(wamp | xammp)

1.后台接口需要做跨域设置

(1)在服务端利用Access-Control-Allow-Origin响应头解决

设置Access-Control-Allow-Origin:*,允许所有域名的脚本访问该资源。

如果考虑到安全问题,也可以设置Access-Control-Allow-Origin:www.build.im 允许特定域名访问

(2)服务器做反向代理

2.打包文件单独放置一个服务器

(1)把react 项目 build 打包后 复制build 里面的文件到web服务器的根目录

( 2 ) 同时需要在web根目录放置.htaccess文件文件内容为:(当服务器出现找不到路由时自动回到index.html 路由由react-router 接管)

附备注:

前端本地开发时会存在跨域问题,如果项目是用creat-react-app cli 创建的,则直接在package.json 文件添加 api 地址目录即可:"proxy": “www.api.com:8000” 即可解决跨域问题,如果是自己创建的项目

配置好proxy middlle 中间件 也可以实现代理。本地fecth( ''api/userinfo",fucntion(){} ); 请求会发送到 http://www.online.com:80/api/userinfo 接口上

rush:js;"> proxy: { '/api)': { target: 'http://www.online.com:80/',changeOrigin: true },}
rush:xml;"> Options +FollowSymlinks RewriteEngine On RewriteCond %{REQUEST_FILENAME} !-d RewriteCond %{REQUEST_FILENAME} !-f RewriteRule ^(.*)$ index.html [QSA,PT,L]

二,部署在Nginx web 服务器上

try_files 指令:配置 Nginx/Nginx.conf 文件

rush:plain;"> server { ... location / { try_files $uri /index.html } }

react build 后的文件包里的文件直接放到 Nginx 下的web 目录 即可通过ip 访问

遇到的坑

1、安装使用

rush:bash;"> npm install -g create-react-app

2、生成新项目

rush:js;"> create-react-app my-app

(生成的项目最好不要用驼峰式命名,否则后面生成文件提示也会让你改)

3、进入项目目录并预览

rush:bash;"> cd my-app npm start

接下来就可以在你的浏览器中看到效果

用create-react-app脚手架生成的目录简单,没有多余的文件

但是在打包的时候遇到一点小问题,npm run build后该项目会生成一个build文件,但是我点击其中的index.html文件打开后浏览器是空白页面,这是报的错:

解决办法:在package.json配置文件中加一句:"homepage": ".",

这是build之后的路径问题,改为相对路径后再次打开这个index.html文件就可以正常浏览了。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...