create-react-app搭建React项目,mobx管理状态

1、安装新建

npm install create-react-app -g
create-react-app myapp
cd myapp
启动:
npm start

创建的项目名称不能包含大写字母,否则会报错
* name can no longer contain capital letters

2、Route路由配置

npm install react-router-dom --save

在src目录下新建router.js

import React from 'react'
import {
    BrowserRouter as Router,
    Route
} from 'react-router-dom'
import Home from './views/Home'

const RootRouter = () =>(
    <Router>
        <div>
            <Route exact path="/" component={Home} />
        </div>
    </Router>
)
export default RootRouter

ps: 若添加多个路由配置,需在<Router></Router>里面添加div进行包裹,否则会报错
A <Router> may have only one child element

打开index.js文件,修改

import React from 'react';
import ReactDOM from 'react-dom'
import * as serviceWorker from './serviceWorker';

import RootRouter from './router.js'

ReactDOM.render(<RootRouter />, document.getElementById('root'));
serviceWorker.unregister();

3、配置mobx

1、安装mobx:
npm install mobx mobx-react --save

2、新增store.js

import { observable, action, computed } from "mobx";
class Store {
    //do something
}
export default Store;

3、修改index.js文件

import { Provider } from 'mobx-react'
import Store from './store'
const store = new Store();
ReactDOM.render(
    <Provider store={store}>
        <RootRouter />
    </Provider>
    , document.getElementById('root'));

4、增加less预处理器

1、使用eject 暴露出webpack配置文件,手动修改
npm run eject
2、使用react-app-rewired
3、替换react-scripts包

#自定义 scripts 包方式 
#一个已经发布到 npm 仓库上的包的名字,比如your-scripts,里面包含了修改过的 webpack 配置
$ create-react-app foo --scripts-version 自定义包

1)、使用react-app-rewired
npm i --save-dev react-app-rewired

在项目根目录下创建config-overrides.js文件

module.exports = function override(config, env) {
  //do stuff with the webpack config...
  return config;
}

修改package.json文件的启动配置
"start": "react-app-rewired start"
2)、配置less使用
npm install --save-dev react-app-rewire-less

修改config-overrides.js文件

const rewireLess = require('react-app-rewire-less');
module.exports = function override(config, env) {
  config = rewireLess(config, env);
  return config;
}

5、常见问题

1、安装react-router-dom后,启动'npm start'会报错 react-scripts 不是内部或外部命令,也不是可运行的程序

  • 原因:因为create-react-app 默认是使用yarn 安装的, 可以在create-react-app 创建项目指定使用npm安装 带上 --use-npm create-react-app myapp --use-npm
  • 解决办法: npm install

2、安装使用mobx后报错 Support for the experimental syntax 'decorators-legacy' isn't currently enabled (3:5):

  • 原因:装饰器语法目前没有被支持
  • 解决办法:添加相关配置以支持装饰器
    npm install react-app-rewire-mobx --save-dev
    修改config-overrides.js文件
const rewireMobX = require("react-app-rewire-mobx");
module.exports = function override(config, env) {
  config = rewireMobX(config, env);

  return config;
};

3、报错
The 'decorators' plugin requires a 'decoratorsBeforeExport' option, whose value must be a boolean. If you are migrating from Babylon/Babel 6 or want to use the old decorators proposal, you should use the 'decorators-legacy' plugin instead of 'decorators'.

  • 原因:最新版本的create-react-app 生成的项目已经是基于babel7了, 旧版的babel-plugin-transform-decorators-legacy已经不用
  • 解决:
    1)安装npm i @babel/plugin-proposal-decorators --save
    2)修改config-overrides.js文件如下:
    删除const rewireMobX = require("react-app-rewire-mobx")
    config = injectBabelPlugin(["@babel/plugin-proposal-decorators",{legacy:true}],config);
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 160,108评论 4 364
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,699评论 1 296
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 109,812评论 0 244
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 44,236评论 0 213
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,583评论 3 288
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,739评论 1 222
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,957评论 2 315
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,704评论 0 204
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,447评论 1 246
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,643评论 2 249
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,133评论 1 261
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,486评论 3 256
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,151评论 3 238
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,108评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,889评论 0 197
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,782评论 2 277
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,681评论 2 272

推荐阅读更多精彩内容