react项目创建流程
react 项目搭建
系统: windows
1.安装 node
node 下载地址.一路 next
如果遇到 windows 没有权限安装 msi 文件.打开 cmd,运行
msiexec /package 文件路径
.
查看是否安装成功,打开终端
node -v
npm -v
2.安装 vscode 编辑器
vscode 下载地址.一路 next
3.安装 react 项目脚手架
打开终端
npm install -g create-react-app
4.创建 react 项目
create-react-app myApp
cd myApp
npm install
npm start
code .
5.安装项目依赖
npm i react-router-dom mobx mobx-react axios qs --save
配置装饰器语法支持
npm i --save-dev @babel/plugin-proposal-class-properties @babel/plugin-proposal-decorators
解压 webpack 配置
npm run eject
修改webpack.config.dev.js
和webpack.config.prod.js
{
test: /\.(js|mjs|jsx|ts|tsx)$/,
include: paths.appSrc,
loader: require.resolve('babel-loader'),
options: {
customize: require.resolve('babel-preset-react-app/webpack-overrides'),
plugins: [
+ ['@babel/plugin-proposal-decorators', { legacy: true }],
+ ['@babel/plugin-proposal-class-properties', { loose: true }],
[
require.resolve('babel-plugin-named-asset-import'),
{
loaderMap: {
svg: {
ReactComponent: '@svgr/webpack?-prettier,-svgo![path]'
}
}
}
]
],
// This is a feature of `babel-loader` for webpack (not Babel itself).
// It enables caching results in ./node_modules/.cache/babel-loader/
// directory for faster rebuilds.
cacheDirectory: true,
// Don't waste time on Gzipping the cache
cacheCompression: false
}
}
6.配置路由
在项目中新建src\pages
文件夹.
新建页面文件src\pages\Home\index.js
// Home\index.js
/**
* @name Home
* @desc 首页
*/
import React, { Component } from 'react'
class Home extends Component {
render() {
return (
<div>
<h1>Home</h1>
</div>
)
}
}
export default Home
新建router.js
/**
* @name Router
* @desc 页面路由配置
*/
import React, { Component } from 'react'
import { Switch, Route, Redirect } from 'react-router-dom'
import Home from './pages/Home'
class Router extends Component {
render() {
return (
<Switch>
<Redirect path="/" to="/home" exact />
<Route path="/home" component={Home} />
</Switch>
)
}
}
export default Router
7.配置 http 请求插件
新建src\utils\axios.js
import axios from 'axios'
import qs from 'qs'
const axiosIns = axios.create({
baseURL: '/',
timeout: 10000,
responseType: 'json',
transformRequest: [data => qs.stringify(data)],
headers: {
'Content-Type': 'application/x-www-form-urlencoded;charset=utf-8'
}
})
axiosIns.interceptors.request.use(
config => {
return config
},
error => Promise.reject(error)
)
axiosIns.interceptors.response.use(result => result.data, error => Promise.reject(error))
const get = (url, params = null, config = {}) => axiosIns.get(url, { ...config, params })
const post = axiosIns.post
const all = axiosIns.all
export { get, post, all }
8.配置状态管理插件
8.1 新建src\utils\mobx-store.js
/**
* @name Store
* @desc store 构造器
*/
import { action, configure } from 'mobx'
configure({ enforceActions: 'observed' })
class Store {
constructor(modules) {
Object.keys(modules).forEach(moduleName => {
this[moduleName] = new modules[moduleName]({
mapStore: this.mapStore.bind(this),
rootState: this.rootState
})
})
}
rootState = {}
mapStore(moduleName) {
if (moduleName) {
return this[moduleName] ? this[moduleName] : console.error(new Error(`has no store named "${moduleName}"`))
} else {
return this
}
}
}
let $mapStore = null
let $rootState = null
class StoreModule {
constructor({ mapStore, rootState }) {
$mapStore = mapStore
$rootState = rootState
}
mapStore(name) {
return $mapStore(name)
}
getRootState() {
return $rootState
}
setState(options) {
action(opt => {
Object.keys(opt).forEach(key => {
if (Object.prototype.hasOwnProperty.call(this, key)) {
this[key] = opt[key]
} else {
console.error(new Error(`mobx action "setState": has no attribute named "${key}"`))
}
})
})(options)
}
}
export { Store, StoreModule }
8.2 创建一个状态模块,新建src\store\test-store.js
/**
* @name Test
* @desc
*/
import { observable, action, configure } from 'mobx'
import { StoreModule } from '../utils/mobx-store'
configure({ enforceActions: 'observed' })
class Test extends StoreModule {
@observable
msg = ''
@action.bound
handleChangeMsg(e) {
this.setState({ msg: e.target.value })
}
}
export default Test
8.3 配置 store
新建src\store\index.js
/**
* @name Store
* @desc 合并全部子模块的store
*/
import { Store } from '../utils/mobx-store'
import Test from './test-store.js'
export default new Store({ Test })
9.注入 router 和 store
修改index.js
import React from 'react'
import ReactDOM from 'react-dom'
import { BrowserRouter } from 'react-router-dom'
import { Provider } from 'mobx-react'
import store from './store'
import App from './App'
ReactDOM.render(
<Provider {...store}>
<BrowserRouter>
<App />
</BrowserRouter>
</Provider>,
document.getElementById('root')
)
修改App.js
import React, { Component } from 'react'
import Routes from './router'
class App extends Component {
render() {
return (
<div classes="container">
<Routes />
</div>
)
}
}
export default App
修改src\pages\Home\index.js
/**
* @name Home
* @desc 首页
* @author
* @version
*/
import React, { Component } from 'react'
import { inject, observer } from 'mobx-react'
@inject('Test')
@observer
class Home extends Component {
render() {
return (
<div>
<h1>Home</h1>
<p>msg: {this.props.Test.msg}</p>
<p>
<input type="text" value={this.props.Test.msg} onChange={this.props.Test.handleChangeMsg} />
</p>
</div>
)
}
}
export default Home
11.http 请求例子
// src\store\test-store.js
/**
* @name Test
* @desc
*/
import { observable, action, configure } from 'mobx'
import { StoreModule } from '../utils/mobx-store'
import { post } from '../utils/axios'
configure({ enforceActions: true })
class Test extends StoreModule {
@observable
msg = ''
@action.bound
handleChangeMsg(e) {
this.setState({ msg: e.target.value })
}
@action.bound
async getSomething() {
try {
const res = await post('/some-data', { type: 'news' })
} catch (err) {
console.error(err)
}
}
}
export default Test
12.打包
npm run build
安装本地服务器启动工具
npm install -g serve
启动打包的项目
serve -s ./build
来源:https://segmentfault.com/a/1190000017109354
react项目创建流程的更多相关文章
- ADF 项目创建流程
ADF 项目创建流程: 1.首先建好应用 2.创建model,UI 3.创建EO,VO,AO, VL 4.设置EO的属性 5.新建lov 6.设置VO的View Accessors,并设置Attrib ...
- react-create-app 构建react项目的流程以及需要注意的地方
Hello 小伙伴们,如果觉得本文还不错,记得给个 star , 小伙伴们的 star 是我持续更新的动力!GitHub 地址 React 系列文章代码地址 一 目录 不折腾的前端,和咸鱼有什么区别 ...
- cocos2dx3.0项目创建流程
cocos2dx3.0不是beta,新增了wp项目创建的支持 但不知道为啥非beta版本号的tools文件夹中取消了project-creator,可能有更改吧 没有这个工具还挺麻烦.就自己手动创建c ...
- SpringBoot项目创建流程--SpringMVC
SpringBoot项目创建步骤 1. 创建SpringBoot工程 (1) File → New → Project → Spring Initilizr (2) Name:MySpringBoot ...
- vue项目创建流程和使用
vue项目的创建 npm run dev 让项目执行起来 #下载vuex npm install vuex --save#下载axiosnpm install axios --save 当我们生成项目 ...
- ASP.NET三层架构项目创建流程
1.进入VS2010,新建项目—>Visual C#—>Web—>ASP.NET空Web应用程序,如图所示: 2.在解决方案处右击—>新建项目—>Windows—> ...
- DRF项目创建流程(1)
一 web应用模式 前后端不分离 前后端分离 二 RESTFUL API规范 REST全称是Representational State Transfer,中文意思是表述(编者注:通常译为表征)性状态 ...
- react项目后台及上线步骤
应同学要求,本人将react项目创建后台及上线流程书写如下: 前端部分 略…… 后台部分 (注:这里的后台是用的nodejs搭建的,使用的是express框架+ejs模板) 首先通过express快速 ...
- 【react npm】解决用npmstart启动别人的react项目的问题1:sha1-xxx checksum failed wanted sha1-xxx but got sha512-xxx. (10700 bytes)
1.npm是nodejs的包管理器,相当于php的composer,python的pip,用于安装各种包. 2.一般来说,别人拷给你的react项目不会带依赖包的,因为太大了,需要用npm命令自己安装 ...
随机推荐
- 图解JAVA容器核心类库
JAVA容器详解 类继承结构图 HashMap 1. 对象的HashCode是用来在散列存储结构中确定对象的存储地址的. 2. 如果两个对象的HashCode相同,即在数组中的地址相同.而数组的元 ...
- Labview学习之路(四)公式和公式节点
在labview里边,有公式和公式节点两个控件都可以实现表达复杂表达式的功能 公式 位置: 程序框图---编程---Express---算数与比较---公式 用法: 点开后是这个样子 可以任意添加输出 ...
- 关于SpringBoot集成JDBCTemplate的RowMapper问题
JdbcTemplate 是Spring提供的一套JDBC模板框架,利用AOP 技术来解决直接使用JDBC时大量重复代码的问题.JdbcTemplate虽然没有MyBatis 那么灵活,但是直接使用J ...
- 初级知识点一——C#中的值类型与引用类型
从C#语言的定义中可以知道,C#支持两种值类型,分别是 值类型和引用类型,那么两者的区别到底在哪儿呢? 值类型特点: 1. 值类型包含 a 预定义的值类型 b 用户自定义的值类型(struct) 2. ...
- CentOS yum 安装时错误 Errno 14 Couldn't resolve host 解决办法
在虚拟机上安装完CentOS6.5之后,首次使用时yum命令安装软件时,出现一堆的” Errno 14 Couldn't resolve host”这个问题. 上网上查了半天,很多都说在/etc/re ...
- Pandoanload涅槃重生,小白羊重出江湖?
Pandoanload涅槃重生,小白羊重出江湖? 科技是把双刃剑,一方面能够砸烂愚昧和落后,另一方面也可能带给人类无尽的灾难. 原子物理理论的发展是的人类掌握了核能技术但是也带来了广岛和长崎的核灾难, ...
- javascript面试题(二)
24. function foo() { } var oldName = foo.name; foo.name = "bar"; [oldName, foo.name] // [f ...
- Count(*) 与 count(field) 一样吗?
有这么个表: 执行 select count(*) from hy_test select count(deptno) from hy_test 都得到 5 但执行 select count(name ...
- 交换机&&路由器
交换机 交换机就是一种信号转发设备,它帮助两个网络节点进行信号的传输 路由器 路由器路由器,要了解什么是路由器,首先我们要先明白何为'路由'? 路由:是指把数据从一个地方传送到另一个地方的行为和动作 ...
- Python实现加密的RAR文件解压(密码已知)
博主之前在网上找了很多资料,发现rarfile库不能直接调用,需要安装unrar模块,下面将详细介绍整个实现流程. 第一步:安装unrar模块,直接pip install unrar可能会找不到库,需 ...