React项目搭建与部署

转载:https://www.cnblogs.com/jackson-yqj/p/10095892.html

一,介绍与需求
1.1,介绍
1.1.1,React简介
React 是一个用于构建用户界面的 JAVASCRIPT 库。
React主要用于构建UI,很多人认为 React 是 MVC 中的 V(视图)。
React 起源于 Facebook 的内部项目,用来架设 Instagram 的网站,并于 2013 年 5 月开源。
React 拥有较高的性能,代码逻辑非常简单,越来越多的人已开始关注和使用它。
1.1.2,React特点
声明式设计:React采用声明范式,可以轻松描述应用。
高效:React通过对DOM的模拟,最大限度地减少与DOM的交互。
灵活:React可以与已知的库或框架很好地配合。
JSX:JSX 是 JavaScript 语法的扩展。React 开发不一定使用 JSX ,但我们建议使用它。
组件:通过 React 构建组件,使得代码更加容易得到复用,能够很好的应用在大项目的开发中。
单向响应的数据流:React 实现了单向响应的数据流,从而减少了重复代码,这也是它为什么比传统数据绑定更简单。
1.2,需求

二,环境搭建与项目框架
2.1,环境搭建
1,安装NODE,

2,安装webpack

1  npm install -g webpack 

3,配置淘宝镜像

使用淘宝定制的 cnpm (gzip 压缩支持) 命令行工具代替默认的 npm

1 npm install -g cnpm --registry=https://registry.npm.taobao.org
2 npm config set registry https://registry.npm.taobao.org

4,安装create-react-app

1 cnpm install -g create-react-app

5,创建项目

1 create-react-app my-project//创建项目
2 cd my-project/ 

6,本地服务启动

1 npm run start//启动本地server用于开发

2.2,项目框架
|-node_modules //项目包
|-public //一般用于存放静态文件,打包时会被直接复制到输出目录(./buidle)
|-src //项目源代码
| |-asserts //用于存放静态资源,打包时会经过 webpack 处理
| |-components //组件 存放 React 组件,一般是该项目公用的无状态组件
| |-containers //页面视图
| |-routes //路由 存放需要 connect model 的路由组件
| |-App.js //入口文件
| |-index //注册路由与服务
| |- serviceWorker //开发配置
|-package.json //包管理代码
|-.gitignore //Git忽略文件

三,常用集成与配置
3.1,路由集成与配置使用
React Router 是一个基于 React 之上的强大路由库,它可以让你向应用中快速地添加视图和数据流,同时保持页面与 URL 间的同步。react-router

1 npm install react-router@4.3.1 --save

在这里插入图片描述

Router下面只能包含一个盒子标签,类似这里的div。
Link代表一个链接,在html界面中会解析成a标签。作为一个链接,必须有一个to属性,代表链接地址。这个链接地址是一个相对路径。
Route,是下面要说的组件,有一个path属性和一个组件属性(可以是component、render等等)。

   render(){
          return (
              <Router>
                  <div>
                      <ul>
                          <li><Link to="/home">首页</Link></li>
                          <li><Link to="/other">其他页</Link></li>
                      </ul>
                      <Route path="/home" component={Home}/>
                     <Route path="/other" component={Other}/>
                 </div>
             </Router>
         )
 }

路由支持嵌套,代码如下:

  const Root = () => (
     <div>
        <Switch>
           <Route
              path="/"
              render={props => (
                 <App>
                    <Switch>
                       <Route path="/" exact component={Home} />
                      <Route path="/home" component={Home} />
                      <Route path="/test" component={Test} />
                      <Route path="/message/:id/:TestId" component={Message} />
                       {/*路由不正确时,默认跳回home页面*/}
                      <Route render={() => <Redirect to="/" />} />
                   </Switch>
                </App>
             )}
          />
       </Switch>
    </div>
 );
  
 export default Root;

3.2,redux集成与配置使用
React是单向数据流,所以有些情况下单单依赖React自身无法实现组件之间的通信,故此需要redux

需要安装Redux相关依赖,由于不同版本之间可能存在兼容性问题,所以安装的时候最好制定版本:

1 npm install redux@3.7.2 --save
2 npm install redux-thunk@2.1.0 --save
3 npm install react-redux@5.0.6 --save

然后就可以在项目中引入redux了,可以像如下方式组织目录结构:
在这里插入图片描述

3.3,fetch集成与配置使用
关于请求数据有很多种方式,这里采用的是fetch

1 npm install fetch --save
可以简单封装一下,如下:

  import 'whatwg-fetch'
  import loggerService from './logger'
  
  let notAuthorizedCounter = 0;
  let fetchService = {
      fetch: (url, method, header, body) => {
          if (!header) {
              header = {}
          }
 
         return fetchService[method.toLowerCase()](url, header, body).catch(function(exception) {
             loggerService.log('fetchService failed:', exception);
 
             // token过期,重新获取token并发起请求
             if (exception.code === '401' || exception.code === '403') {
                 notAuthorizedCounter++;
                 // 最多重试3次
                 if (notAuthorizedCounter > 2) {
                     notAuthorizedCounter = 0;
                     loggerService.warn("401 or 403 received. Max attemps reached.");
                     return;
                 } else {
                     return fetchService.fetch(url, method, header, body);
                 }
             }
         });
     },
     get: (url, header) => {
         return fetch(url, {
             method: 'GET',
             headers: header
         }).then((response) => {
             return response.json();
         });
     },
     post: (url, header, body) => {
         header['Content-Type'] = 'application/json';
         return fetch(url, {
             method: 'POST',
             headers: header,
             body: JSON.stringify(body)
         }).then((response) => {
             return response.json();
         });
     }
 };
 export default fetchService;

3.4,UI组件集成与配置使用
基于React的UI组件在这里推荐两个,一个是蚂蚁金服的Ant Design;另外一个是Material-UI。

两个都很不错,这里使用的是Ant Design。

1 npm install antd --save

请注意 react >= 16.6.3和react-dom >= 16.6.3 是对等依赖

1 npm install @material-ui/core

3.5,国际化方案
采用的是常用的react-intl

1 npm install react-intl --save

四,项目部署与问题
4.1,项目部署
首先对项目进行打包。

1 npm run build

通过以下命令可以在本地环境运行打包后的项目。

1 serve -s build

4.2,问题与注意事项
PropTypes 的使用

JavaScript 是弱类型语言,所以请尽量声明 propTypes 对 props 进行校验,以减少不必要的问题。

  import React from 'react';
  import PropTypes from 'prop-types'
  
  class PropTypesList extends React.Component {
      static propTypes = {//校验
         title: PropTypes.string,
      };
      static defaultProps = {//设置默认值
         title:"PropTypes 的应用实例"//添加默认值
     };
     constructor(props) {
         super(props);
         this.state = {
 
         }
     }
     render() {
         const { title} = this.props
         return (
             <div>
                 <p>{title}</p>
             </div>
         );
     }
 }
 
 export default PropTypesList ;

内置的 prop type 有:

PropTypes.array
PropTypes.bool
PropTypes.func
PropTypes.number
PropTypes.object
PropTypes.string
PropTypes.node,// 字符串,DOM 元素或包含这些类型的数组。
PropTypes.element, // React 元素
PropTypes.instanceOf(Message), // 用 JS 的 instanceof 操作符声明 prop 为类的实例。
PropTypes.oneOf([‘News’, ‘Photos’]), // 用 enum 来限制 prop 只接受指定的值。
PropTypes.oneOfType([ PropTypes.string, PropTypes.number, PropTypes.instanceOf(Message) ]), // 指定的多个对象类型中的一个
PropTypes.arrayOf(PropTypes.number),// 指定类型组成的数组
PropTypes.objectOf(PropTypes.number), // 指定类型的属性构成的对象
PropTypes.shape({ color: PropTypes.string, fontSize:PropTypes.number }), // 特定形状参数的对象
PropTypes.func.isRequired, // 不可空的任意类型
PropTypes.any.isRequired,// 以后任意类型加上 isRequired 来使 prop 不可空。
customProp: function(props, propName, componentName) { if (!/matchme/.test(props[propName])) { return new Error(‘Validation failed!’); } } },// 自定义验证器。如果验证失败需要返回一个 Error 对象。不要直接 // 使用 console.warn 或抛异常,因为这样 oneOfType 会失效。

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值