刚开始学习 内容会逐渐完善
1、创建 react
1.1 这是js的 react项目创建方式
npx create-react-app react-app
1.2 这是ts的react项目创建方式
npx create-react-app my-app --template typescript
// 如果使用这种创建方式 就需要安装相关的 库
npm i react react-dom react-redux typescript --save
安装@types声明库
npm i @types/react @types/react-dom @types/react-redux --save-dev
启动后,可以通过以下地址访问项目:
http://localhost:3000/
目录
    ├─ /node_modules
    ├─ /public
    |  ├─ favicon.ico
    |  ├─ index.html
-   |  ├─ logo192.png
-   |  ├─ logo512.png
-   |  ├─ mainfest.json
-   |  └─ robots.txt
    ├─ /src
-   |  ├─ App.css
    |  ├─ App.js
-   |  ├─ App.test.js      
-   |  ├─ index.css
    |  ├─ index.js
-   |  ├─ logo.svg
-   |  ├─ reportWebVitals.js
-   |  └─ setupTests.js
    ├─ .gitignore
    ├─ package.json
    ├─ README.md
2 接下来,删除一般项目中用不到的文件,最简化项目。
    ├─ /node_modules
    ├─ /public
    |  ├─ favicon.ico
    |  └─ index.html
    ├─ /src
    |  ├─ App.js
    |  └─ index.js
    ├─ .gitignore
    ├─ package.json
    ├─ README.md
    └─ yarn.lock
这样清洁多了 方便我们后面的修改,但是这样会有很多报错,因为删除许多文件
3 逐个修改以下文件:
src/App.js:
function App() {
    return <div className="App">React-App</div>
}
export default App
src/index.js:
import React from 'react'
import ReactDOM from 'react-dom'
import App from './App'
ReactDOM.render(<App />, document.getElementById('root'))
public/index.html:
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="utf-8" />
    <link rel="icon" href="%PUBLIC_URL%/favicon.ico" />
    <meta name="viewport" content="width=device-width, initial-scale=1" />
    <title>React App</title>
  </head>
  <body>
    <noscript>You need to enable JavaScript to run this app.</noscript>
    <div id="root"></div>
  </body>
</html>
4 react生命周期
4.1初始化阶段
4.1.1 设置组件的默认属性
static defaultProps = {
    name: 'start',
    age:23
};
//or
Counter.defaltProps={name:'start'}
4.1.2、设置组件的初始化状态
constructor() {
    super();
    this.state = {number: 0}
}
4.1.3、componentWillMount()
组件即将被渲染到页面之前触发,此时可以进行开启定时器、向服务器发送请求等操作
4.1.4、render()
渲染组件
4.1.5、componentDidMount()
组件已经被渲染到页面中后触发:此时页面中有了真正的DOM的元素,可以进行DOM相关的操作
(DOM挂在后执行)
4.2、运行中阶段
4.2.1 componentWillReceiveProps()
组件接收到属性时触发
4.2.2 shouldComponentUpdate()
当组件接收到新属性,或者组件的状态发生改变时触发。组件首次渲染时并不会触发
shouldComponentUpdate(newProps, newState) {
    if (newProps.number < 5) return true;
    return false
}
该钩子函数可以接收到两个参数,新的属性和状态,返回true/false来控制组件是否需要更新。
一个React项目需要更新一个小组件时,很可能需要父组件更新自己的状态。而一个父组件的重新更新会造成它旗下所有的子组件重新执行render()方法,形成新的虚拟DOM,再用diff算法对新旧虚拟DOM进行结构和属性的比较,决定组件是否需要重新渲染
无疑这样的操作会造成很多的性能浪费,所以我们开发者可以根据项目的业务逻辑在shouldComponentUpdate()中加入条件判断,从而优化性能
例如React中的就提供了一个`PureComponent`的类,当我们的组件继承于它时,组件更新时就会默认先比较新旧属性和状态,
从而决定组件是否更新。值得注意的是,`PureComponent`进行的是浅比较,所以组件状态或属性改变时,
都需要返回一个新的对象或数组
4.2.3、componentWillUpdate()
组件被更新完成后触发。页面中产生了新的DOM的元素,可以进行DOM操作
4.3、销毁阶段
4.3.1 componentWillUnmount()
组件被销毁时触发。这里我们可以进行一些清理操作,例如清理定时器,取消Redux的订阅事件等等。