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 相关文章推荐
js 覆盖和重载 函数
Sep 25 Javascript
JavaScript栏目列表隐藏/显示简单实现
Apr 03 Javascript
第四篇Bootstrap网格系统偏移列和嵌套列
Jun 21 Javascript
js css自定义分页效果
Feb 24 Javascript
正则表达式基本语法及表单验证操作详解【基于JS】
Apr 07 Javascript
最通俗易懂的javascript变量提升详解
Aug 05 Javascript
node中使用es5/6以及支持性与性能对比
Aug 11 Javascript
Vue.js通用应用框架-Nuxt.js的上手教程
Dec 25 Javascript
webpack4+react多页面架构的实现
Oct 25 Javascript
javascript对HTML字符转义与反转义
Dec 13 Javascript
vue+elementUI 复杂表单的验证、数据提交方案问题
Jun 24 Javascript
JS中数组实现代码(倒序遍历数组,数组连接字符串)
Dec 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设计模式 Builder(建造者模式)
2011/06/26 PHP
php中session使用示例
2014/03/29 PHP
PHP return语句另类用法不止是在函数中
2014/09/17 PHP
PHP多种序列化/反序列化的方法详解
2017/06/23 PHP
如何用JavaScript动态呼叫函数(两种方式)
2013/05/03 Javascript
js鼠标及对象坐标控制属性详细解析
2013/12/14 Javascript
JavaScript获取网页表单提交方式的方法
2015/04/02 Javascript
JavaScript实现的圆形浮动标签云效果实例
2015/08/06 Javascript
window.location.hash知识汇总
2015/11/09 Javascript
js中利用tagname和id获取元素的方法
2016/01/03 Javascript
JS中dom0级事件和dom2级事件的区别介绍
2016/05/05 Javascript
JS中Array数组学习总结
2017/01/18 Javascript
vue实现登陆登出的实现示例
2017/09/15 Javascript
用Node编写RESTful API接口的示例代码
2018/07/04 Javascript
前端防止用户重复提交js实现代码示例
2018/09/07 Javascript
解决VUE双向绑定失效的问题
2019/10/29 Javascript
vue导入.md文件的步骤(markdown转HTML)
2020/12/31 Vue.js
[50:58]2018DOTA2亚洲邀请赛3月29日 小组赛A组OpTic VS Newbee
2018/03/30 DOTA
jupyter安装小结
2016/03/13 Python
python字符串中的单双引
2017/02/16 Python
python数据类型判断type与isinstance的区别实例解析
2017/10/31 Python
Python定义二叉树及4种遍历方法实例详解
2018/07/05 Python
python调用百度语音识别api
2018/08/30 Python
python K近邻算法的kd树实现
2018/09/06 Python
Python 创建新文件时避免覆盖已有的同名文件的解决方法
2018/11/16 Python
Python对excel文档的操作方法详解
2018/12/10 Python
Python实现寻找回文数字过程解析
2020/06/09 Python
加拿大领先家居家具网上购物:Aosom.ca
2020/05/27 全球购物
财务方面个人工作的自我评价
2013/12/28 职场文书
顶撞领导检讨书
2014/01/29 职场文书
创业计划书的主要内容有哪些
2014/01/29 职场文书
青年文明号口号
2014/06/17 职场文书
党性锻炼的心得体会
2014/09/03 职场文书
运动会铅球比赛加油稿
2014/09/26 职场文书
市级三好生竞选稿
2015/11/21 职场文书
初中地理教学反思
2016/02/19 职场文书