react build 后打包发布总结


Posted in Javascript onAugust 24, 2018

一,部署在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  接口上

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

二,部署在nginx  web 服务器上

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

server {
 ...
 location / {
  try_files $uri /index.html
 }
}

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

遇到的坑

1、安装使用

npm install -g create-react-app

2、生成新项目

create-react-app my-app

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

3、进入项目目录并预览

cd my-app
npm start

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

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

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

react build 后打包发布总结

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

react build 后打包发布总结

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

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
关于B/S判断浏览器断开的问题讨论
Oct 29 Javascript
EXT中xtype的含义分析
Jan 07 Javascript
js随机生成网页背景颜色的方法
Feb 26 Javascript
JS实现跟随鼠标立体翻转图片的方法
May 04 Javascript
requireJS使用指南
Apr 27 Javascript
JavaScript中常见的八个陷阱总结
Jun 28 Javascript
使用重写url机制实现验证码换一张功能
Aug 01 Javascript
浅谈vue中关于checkbox数据绑定v-model指令的个人理解
Nov 14 Javascript
小程序click-scroll组件设计
Jun 18 Javascript
Vue路由对象属性 .meta $route.matched详解
Nov 04 Javascript
Jquery滑动门/tab切换实现方法完整示例
Jun 05 jQuery
Antd中单个DatePicker限定时间输入范围操作
Oct 29 Javascript
vue项目部署到Apache服务器中遇到的问题解决
Aug 24 #Javascript
Vue.js获取被选择的option的value和text值方法
Aug 24 #Javascript
element-ui中select组件绑定值改变,触发change事件方法
Aug 24 #Javascript
详解JS转换数值函数Number()、parseInt()、parseFloat()
Aug 24 #Javascript
浅谈ElementUI中switch回调函数change的参数问题
Aug 24 #Javascript
深入理解JS中Number(),parseInt(),parseFloat()三者比较
Aug 24 #Javascript
微信小程序支付PHP代码
Aug 23 #Javascript
You might like
php变量作用域的深入解析
2013/06/03 PHP
PHP下通过QRCode类库创建中间带网站LOGO的二维码
2014/07/12 PHP
在win7中搭建Linux+PHP 开发环境
2014/10/08 PHP
PHP中的switch语句的用法实例详解
2015/10/21 PHP
laravel实现分页样式替换示例代码(增加首、尾页)
2017/09/22 PHP
PHP SESSION机制的理解与实例
2019/03/22 PHP
YII2框架使用控制台命令的方法分析
2020/03/18 PHP
巧妙破除网页右键禁用的十大绝招
2006/08/12 Javascript
jquery remove方法应用详解
2012/11/22 Javascript
js获取html文件的思路及示例
2013/09/17 Javascript
js获取客户端外网ip的简单实例
2013/11/21 Javascript
jQuery$命名冲突怎么办如何解决
2014/01/16 Javascript
javascript相关事件的几个概念
2015/05/21 Javascript
JavaScript判断undefined类型的正确方法
2015/06/30 Javascript
javascript中JSON对象与JSON字符串相互转换实例
2015/07/11 Javascript
基于jQuery实现多标签页切换的效果(web前端开发)
2016/07/24 Javascript
vuejs响应用户事件(如点击事件)
2017/03/14 Javascript
vue + vuex todolist的实现示例代码
2018/03/09 Javascript
JS一次前端面试经历记录
2020/03/19 Javascript
JS绘图Flot如何实现可选显示曲线图功能
2020/10/16 Javascript
[02:08]我的刀塔不可能这么可爱 胡晓桃_1
2014/06/20 DOTA
Python中不同进制互相转换(二进制、八进制、十进制和十六进制)
2015/04/05 Python
python批量替换多文件字符串问题详解
2018/04/22 Python
python3使用matplotlib绘制散点图
2019/03/19 Python
Python使用pandas和xlsxwriter读写xlsx文件的方法示例
2019/04/09 Python
python自动循环定时开关机(非重启)测试
2019/08/26 Python
Keras使用ImageNet上预训练的模型方式
2020/05/23 Python
CSS3+js实现简单的时钟特效
2015/03/18 HTML / CSS
HTML5中微数据概述及在搜索引擎中的使用举例
2013/02/07 HTML / CSS
排序都有哪几种方法?请列举。用JAVA实现一个快速排序
2014/02/16 面试题
室内设计专业个人的自我评价
2013/12/18 职场文书
生日礼品店创业计划书范文
2014/03/21 职场文书
结婚老公保证书
2015/02/26 职场文书
微观世界观后感
2015/06/10 职场文书
靠谱的活动总结
2019/04/16 职场文书
Springboot使用Spring Data JPA实现数据库操作
2021/06/30 Java/Android