create-react-app的使用

2017.11.14更新

关于自定义create-react-app,我们可以选择社区提供的解决方案react-app-rewired来满足我们的大部分自定义需求

将所有配置文件暴露出来

运行

npm run eject

注意,这个是不可逆操作,它会将所有配置文件,包括webpack, eslint, babel的配置文件全部暴露出来,以便你可以全权控制所有的配置细节,考虑到create-react-app自身的完整性,如果不是万不得已的情况,尽量不要执行这个操作

关于使用css preprocessor

因为react官方是推荐进行组件复用,而不是进行样式复用,所以在基于这个前提下,像less或者sass这样的预处理器,所能发挥的作用非常的有限。当然,如果你觉得你有必须这样做的理由,可以采用以下的办法

1.使用预处理器的命令行

如使用sass
第一步,安装

npm install --save node-sass-chokidar

第二步,添加处理命令

"scripts": {
+    "build-css": "node-sass-chokidar src/ -o src/",
+    "watch-css": "npm run build-css && node-sass-chokidar src/ -o src/ --watch --recursive",
     "start": "react-scripts start",
     "build": "react-scripts build",
     "test": "react-scripts test --env=jsdom"

只要运行npm run watch-css命令,src目录下的所有.sass文件都会被编译成.css

2.修改webpack配置

运行npm run eject将所有create-react-app的配置文件暴露出来,然后修改webpack配置

添加自定义环境变量

环境变量可以让我们在不同的环境,如dev,production环境,进行不同的配置和操作,比如,很常见的需求就是在dev环境我需要请求测试环境的接口,而在production环境我需要请求线上接口。

使用环境变量

注意

凡是在create-react-app中自定义的环境变量,都需要加上REACT_APP_前缀

在HTML中使用环境变量

<title>%REACT_APP_WEBSITE_NAME%</title>

在JS中使用环境变量

const WEBNAME = process.env.REACT_APP_WEBSITE_NAME

内置的环境变量

create-react-app内置有两个环境变量,PUBLIC_URLNODE_ENV

PUBLIC_URL是静态资源的发布路径,在public/index.html有使用,这个默认值是'',需要自己进行配置

NODE_ENV有三个值,分别对应如下:

  • 运行npm start,为development
  • 运行npm test,为test
  • 运行npm run build,为production

NODE_ENV的值不能手动进行覆盖

定义环境变量

使用命令行

windows

set REACT_APP_SECRET_CODE=abcdef&&npm start

mac

REACT_APP_SECRET_CODE=abcdef npm start

使用.env文件

.env文件放在项目根目录

REACT_APP_SECRET_CODE=abcdef

名字后面也能加后缀,不同后缀的文件对应不同的使用情况

  • .env: 默认使用
  • .env.local:用于本地变量覆盖,这个文件会在除了test环境的所有环境加载
  • .env.development,.env.test,.env.production:在对应的环境加载
  • .env.development.local,.env.test.local,.env.production.local:在对应的环境加载,最高优先级,会覆盖.env.*的配置

加载的优先级从高到低,依次为:

  • npm start: .env.development.local, .env.development, .env.local, .env
  • npm run build: .env.production.local, .env.production, .env.local, .env
  • npm test: .env.test.local, .env.test, .env (note .env.local is missing)

多环境支持

因为create-react-app只支持development,production,test三个环境,当需要对更多环境提供支持的时候(比如,公司有两个测试环境,对应的接口都不一样),就需要修改下配置了。
其实很简单,只需要将create-react-app查找.env文件的一个变量(process.env.NODE_ENV)替换成自己的自定义的一个变量就行了

先运行npm run eject将所有配置项暴露出来
修改config/env.js下前面的几行代码中的其中一句

'use strict';

const fs = require('fs');
const path = require('path');
const paths = require('./paths');

// Make sure that including paths.js after env.js will read .env variables.
delete require.cache[require.resolve('./paths')];

//**************这句代码******************
// const NODE_ENV = process.env.NODE_ENV; 
const NODE_ENV = process.env.FS_ENV
//...

然后,在package.json中添加

"scripts": {
  "start": "node scripts/start.js",
  "build": "node scripts/build.js",
+ "build-test1": "set FS_ENV=test1&&node scripts/build.js",
  "test": "node scripts/test.js --env=jsdom"
},

然后在根目录添加.env.test1,自定义的一个环境文件就能被加载了

上面是添加了一个test1环境,同理还能添加test2,test3······等等

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 215,012评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,628评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,653评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,485评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,574评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,590评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,596评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,340评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,794评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,102评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,276评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,940评论 5 339
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,583评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,201评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,441评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,173评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,136评论 2 352

推荐阅读更多精彩内容

  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,647评论 18 139
  • GitChat技术杂谈 前言 本文较长,为了节省你的阅读时间,在文前列写作思路如下: 什么是 webpack,它要...
    萧玄辞阅读 12,687评论 7 110
  • Spring Boot 参考指南 介绍 转载自:https://www.gitbook.com/book/qbgb...
    毛宇鹏阅读 46,800评论 6 342
  • 这有可能是有史以来假期最长的一个国庆节了,中间顺便还把中秋一起过了。时间也过的很快,你都做了些啥呢?出去旅游、购物...
    1baf5004e29b阅读 767评论 0 0
  • 15年年底本人公司新开的一个项目,用上了mvp模式开发,那个时候还没发现google出了mvp的demo。 首先什...
    大于于阅读 23,253评论 43 87