Skip to content

Latest commit

 

History

History
262 lines (225 loc) · 7.38 KB

README.md

File metadata and controls

262 lines (225 loc) · 7.38 KB

Available Scripts

In the project directory, you can run:

npm start

在开发模式下运行应用程序.
打开 http://localhost:3000 在浏览器中查看它

npm run build

将生产应用程序构建到build文件夹,它正确地将 React 捆绑在生产模式中并优化构建以获得最佳性能

全局安装 以管理者身份打开 CMD 执行 npm i -g serve
在项目路径下 执行 serve -s build 即可脱离编译局 查看项目 http://localhost:5000

npm run eject

注意:这是单向操作。 一旦你'弹出',你就不能回去了!

如果您对构建工具和配置选择不满意,可以随时“弹出”

开发说明

请使用 less 预处理语言编写 css 样式, 使用嵌套的方式
数据请求操作在redux里操作
任何跟数据有关的操作请在智能组件写,通过传值方式传递给木偶组件

简述依赖

项目结构

  • config: 项目(webpack)配置文件
  • node_modules: 项目依赖库
  • scripts: 项目执行脚本
  • build: 生产包
  • computerFile: 开发文件
  • src: 开发源码包
    • axios: 網絡請求 全局配置
    • components: 项目组件文件
    • config: 配置文件
      • asyncComponent.jsx: 懒加载
    • redux:项目数据池所在
      • module: 数据文件存放
      • index.js:数据池对外入口
    • static: 项目静态资源文件
      • css: 样式
      • img: 图片
    • utils: 工具類函數
      • deepCopy.js 深度拷貝函數
    • views:项目页面文件
    • App.js: 项目入口文件
    • index.js:项目全局引入文件
    • router.js: 路由管理
  • package.json: 依赖管理 环境配置
  • package-lock.json: 依赖锁
  • gitgnore: 禁止上传 GIT

项目配置

./package.json

"babel": {
  "plugins": [
      // 按需引入UI库
      [
      "import",
        {
          "libraryName": "antd",
          "libraryDirectory": "es",
          "style": "css"
        }
      ],
      // 修饰器 配置
      [
        "@babel/plugin-proposal-decorators",
        {
          "legacy": true
        }
      ]
  ]
}

./src/index.js

// 热重载
const rootEl = document.getElementById('root')

if (module.hot) {
  module.hot.accept('./App', () => {
    const NextApp = require('./App').default;
    ReactDOM.render(
      <NextApp / > ,
      rootEl
    );
  });
}

ReactDOM.render( < App / > , rootEl);

./config/webpack.config.js

// 配置 less语法

// 43
const lessRegex = /\.less$/;
const lessModuleRegex = /\.module\.less$/;
// 462
{
  test: lessRegex,
  exclude: lessModuleRegex,
  use: getStyleLoaders({ importLoaders: 2 }, 'less-loader'), // 注意第二个参数
},
{
  test: lessModuleRegex,
  use: getStyleLoaders(
  {
    importLoaders: 2,
    modules: true,
    getLocalIdent: getCSSModuleLocalIdent,
  },
  'less-loader' // 注意第二个参数
  )
}
// 110
if (preProcessor === 'less-loader') {
  loaders.push({
    loader: require.resolve(preProcessor),
    options: {
      sourceMap: isEnvProduction && shouldUseSourceMap,
      javascriptEnabled: true // 解决上文报错
    },
  });
} else {
  loaders.push({
    loader: require.resolve(preProcessor),
    options: {
      sourceMap: isEnvProduction ? shouldUseSourceMap : isEnvDevelopment,
    ,
  });
}

React 生命周期

import React from "react";
// 性能提升库
import { fromJS } from "immutable";
import { connect } from "react-redux";
// PropTypes props类型检查
import PropTypes from "prop-types";
import "./index.less";

// @方法 :装饰器写法

// 传入redux
@connect(
  // 数据挂载在当前组件的 props 上
  state => state.one
)
class EntranceGuard extends React.Component {
  // 以随意为每一个属性指定类型。这对于我们检查和处理属性的意外赋值非常有用。
  static propTypes = {
    type: PropTypes.string
  };

  // 设置 props 属性 默认值 就算 外部不传值 也不会报错
  static defaultProps = {
    type: 'hello word'
  }
  /*
    构造函数 添加一个类构造函数来初始化状态 this.state
    注意传递 props 到基础构造函数的
  */
  constructor(props) {
    // 改变this 指向
    super(props);
    /*
    this.state 定义数据,数据是响应的
    修改数据,例子: this.setstate({date: 1})
    */

    this.state = { date: 0 };
    this.changeHandle = this.changeHandle.bind(this);
  }

  // 组件初始化时只调用,以后组件更新不调用,整个生命周期只调用一次,此时可以修改state。
  componentWillMount() {}

  // 组件渲染之后调用,只调用一次。
  componentDidMount() {}

  // 组件初始化时不调用,组件接受新的props时调用。
  componentWillReceiveProps(nextProps) {}
  /*
    react性能优化非常重要的一环。组件接受新的state或者props时调用,我们可以设置在此对比前后两个
    props和state是否相同,如果相同则返回false阻止更新,因为相同的属性状态一定会生成相同的dom树,
    这样就不需要创造新的dom树和旧的dom树进行diff算法对比,节省大量性能,尤其是在dom结构复杂的时候
  */
  shouldComponentUpdate(nextProps, nextState) {
    return !(
      fromJS(nextProps).equals(fromJS(this.props)) &&
      fromJS(nextState).equals(fromJS(this.state))
    );
  }

  // 组件初始化时不调用,只有在组件将要更新时才调用,此时可以修改state
  componentWillUpdate(nextProps, nextState) {}

  // 组件初始化时不调用,组件更新完成后调用,此时可以获取dom节点。
  componentDidUpdate() {}

  // 组件将要卸载时调用,一些事件监听和定时器需要在此时清除。
  componentWillUnmount() {}

  // react最重要的步骤,创建虚拟dom,进行diff算法,更新dom树都在此进行。此时就不能更改state了。
  render() {
    /*
      最外层需要一个元素包裹
      写类 需要 className 因为 class 与 es class语法糖 冲突
    */
    return (
      <div className="less">
        <input type="text" onChange={this.changeHandle} />
        <div>{this.state.date}</div>
      </div>
    );
  }
  changeHandle(vlaue) {
    /*
      方法里访问this时 使用箭头函数
      或者 在构造函数里 通过
        this.changeHandle = this.changeHandle.bind(this)
      传入this
    */
    this.setState({
      date: vlaue.target.value
    });
  }
}

// es6 模块导出
export default EntranceGuard;