一、react-hooks概念

  React中一切皆为组件,React中组件分为类组件和函数组件,在React中如果需要记录一个组件的状态的时候,那么这个组件必须是类组件。那么能否让函数组件拥有类组件的功能?这个时候我们就需要使用hooks。

  Hooks让我们的函数组件拥有了类似类组件的特性,Hook是React16.8中新增的功能,它们允许您在不编写类的情况下使用状态和其他React功能

二、为什么React中需要类组件

  1、需要记录当前组件的状态
  2、需要使用组件的一些生命周期函数

三、类组件与Hooks简单对比

  类组件

  1. import React from "react"
  2.  
  3. export default class App extends React.Component{
  4. constructor(){
  5. super();
  6. this.state = {
  7. count:0
  8. }
  9. this.handleClick = this.handleClick.bind(this);
  10. }
  11. render(){
  12. let {count} = this.state;
  13. return (
  14. <div>
  15. <h2>{count}</h2>
  16. <button onClick={this.handleClick}>修改</button>
  17. </div>
  18. )
  19. }
  20. handleClick(){
  21. this.setState({
  22. count:this.state.count+1
  23. })
  24. }
  25. }

  hooks

  1. import React,{useState} from "react";
  2.  
  3. export default ()=>{
  4. let [count,setCount] = useState(0);
  5. let handleAdd = ()=>setCount(count+1);
  6. return (
  7. <div>
  8. <h2>{count}</h2>
  9. <button onClick={handleAdd}>点击</button>
  10. </div>
  11. )
  12. }

二者对比之后是不是感觉Hooks简单好多了?那么接下来我们来学习Hooks

四、Hooks基本使用

  1、Hooks常用的方法
    useState 、useEffect 、useContext以上三个是hooks经常会用到的一些方法

  2、useState
    useState是react自带的一个hook函数,它的作用就是用来声明状态变量.useState这个函数接收的参数是我们的状态初始值,它返回了一个数组,这个数组的第 [0]项是当

前当前的状态值,第 [1]项是可以改变状态值的方法函数。

  1. import React,{useState} from "react"
  2.  
  3. export default ()=>{
  4. let [count,setCount] = useState(0);
  5. let addCount = ()=>setCount(count+1);
  6. return (
  7. <div>
  8. <h2>{count}</h2>
  9. <button onClick={addCount}>点击</button>
  10. </div>
  11. )
  12. }

  useState : 创建一个状态,这个状态为0
  count : 代表当前状态值也就是0
  setCount : 更新状态的函数
  addCount = ()=>setCount(count+1);调用setCount就可以用来修改状态

  2-1、useState返回的是什么?

  1. const [count,setCount] = useState(0);
  2.  
  3. const state = useState(0);
  4. const count = state[0];
  5. const setCount = state[1]

  注意:

    1、useState一定要写在函数初始的位置不能在循环或判断语句等里面调用,这样是为了让我们的 Hooks 在每次渲染的时候都会按照 相同的顺序 调用,因为这里有一个关键的问题,那就是 useState 需要依赖参照第一次渲染的调用顺序来匹配对于的state,否则 useState 会无法正确返回它对于的state

    2、我们可以在一个函数组件中使用多个

  1. export default ()=>{
  2. let [count,setCount] = useState(0);
  3. let [count,setCount] = useState(0);
  4. let [count,setCount] = useState(0);
  5.  
  6. }

五、useEffect基本使用
  我们写的有状态组件,通常会产生很多的副作用(side effect),比如发起ajax请求获取数据,添加一些监听的注册和取消注册,手动修改dom等等。我们之前都把这些副作用的函数写在生命周期函数钩子里,比如componentDidMount,componentDidUpdate和componentWillUnmount。而现在的useEffect就相当与这些声明周期函数钩子的集合体。它以一抵三。

            (useEffect = componentDidMount + componentDidUpdate+componentWillUnmount)

  5-1、useEffect
    useEffect中有两个参数,第一个参数是一个函数,第二个参数是一个依赖的数据。第二个参数用来决定是否执行里面的操作,可以避免一些不必要的性能损失,只要第二个参数中的成员的值没有改变,就会跳过此次执行。如果传入一个空数组 [ ],那么该effect 只会在组件 mount 和 unmount 时期执行。

  5-2、useEffect模拟componentDidMount && componentDidUpdate

  1. import React,{useState,useEffect} from "react"
  2.  
  3. export default ()=>{
  4. let [title,setTitle] = useState(0);
  5. let updateTitle = ()=>setTitle(title+1);
  6. return (
  7. <div>
  8. <h2>{title}</h2>
  9. <button onClick={updateTitle}>点击</button>
  10. </div>
  11. )
  12.  
  13. //参数是一个函数 每次mount 或者 update都会调用当前函数
  14. useEffect(()=>{
  15. document.title = `页面为${count}`;
  16. })
  17.  
  18. }

  

  5-3、如何只在componentDidMount中执行

  1. import React,{useState,useEffect} from "react"
  2.  
  3. export default ()=>{
  4. let [title,setTitle] = useState(0);
  5. let updateTitle = ()=>setTitle(title+1);
  6. return (
  7. <div>
  8. <h2>{title}</h2>
  9. <button onClick={updateTitle}>点击</button>
  10. </div>
  11. )
  12.  
  13. //将第二个参数设置为一个空数组则只会在componentDidMount中执行
  14. useEffect(()=>{
  15. document.title = `页面为${count}`;
  16. },[])
  17.  
  18. }

  5-2、useEffect模拟componentWillUnMount
  useEffect 中还可以通过让函数返回一个函数来进行一些清理操作,比如取消订阅等

  1. useEffect = (()=>{
  2. return ()=>{
  3. //unmount时调用这里
  4. document.removeEventListener();
  5. }
  6. },[])

四、useEffect 什么时候执行? 

  它会在组件 mount 和 unmount 以及每次重新渲染的时候都会执行,也就是会在 componentDidMount、componentDidUpdate、componentWillUnmount 这三个时期执行

五、hooks的好处
  面向生命周期编程变成了面向业务逻辑编程

【react】---Hooks的基本使用---【巷子】的更多相关文章

  1. 通过 React Hooks 声明式地使用 setInterval

    本文由云+社区发表 作者:Dan Abramov 接触 React Hooks 一定时间的你,也许会碰到一个神奇的问题: setInterval 用起来没你想的简单. Ryan Florence 在他 ...

  2. 初探React Hooks & SSR改造

    Hooks React v16.8 发布了 Hooks,其主要是解决跨组件.组件复用的状态管理问题. 在 class 中组件的状态封装在对象中,然后通过单向数据流来组织组件间的状态交互.这种模式下,跨 ...

  3. React hooks实践

    前言 最近要对旧的项目进行重构,统一使用全新的react技术栈.同时,我们也决定尝试使用React hooks来进行开发,但是,由于React hooks崇尚的是使用(也只能使用)function c ...

  4. 理解 React Hooks

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由志航发表于云+社区专栏 TL;DR 一句话总结 React Hooks 就是在 react 函数组件中,也可以使用类组件(classe ...

  5. React Hooks新特性学习随笔

    React Hooks 是 React 16.8 的新增特性.它可以让你在不编写 class 的情况下使用 state 以及其他的 React 特性. 前言 本篇主要以讲几个常用的api为主. 1.u ...

  6. 关于React Hooks,你不得不知的事

    React Hooks是React 16.8发布以来最吸引人的特性之一.在开始介绍React Hooks之前,让咱们先来理解一下什么是hooks.wikipedia是这样给hook下定义的: In c ...

  7. react hooks 全面转换攻略(三) 全局存储解决方案

    针对 react hooks 的新版本解决方案 一.redux维持原方案 若想要无缝使用原来的 redux,和其配套的中间件 promise,thunk,saga 等等的话 可以使用 redux-re ...

  8. react新特性 react hooks

    本文介绍的是react新特性react hooks,本文面向的是有一定react开发经验的小伙伴,如果你对react还不是很熟悉的话我建议你先学习react并多多联系. 首先我们都知道react有3种 ...

  9. 30分钟精通React今年最劲爆的新特性——React Hooks

    你还在为该使用无状态组件(Function)还是有状态组件(Class)而烦恼吗? --拥有了hooks,你再也不需要写Class了,你的所有组件都将是Function. 你还在为搞不清使用哪个生命周 ...

  10. React Hooks 深入系列 —— 设计模式

    本文是 React Hooks 深入系列的后续.此篇详细介绍了 Hooks 相对 class 的优势所在, 并介绍了相关 api 的设计思想, 同时对 Hooks 如何对齐 class 的生命周期钩子 ...

随机推荐

  1. WebGPU学习(九):学习“fractalCube”示例

    大家好,本文学习Chrome->webgpu-samplers->fractalCube示例. 上一篇博文: WebGPU学习(八):学习"texturedCube"示 ...

  2. Angularjs实现简单的登陆框

    ​ <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&q ...

  3. 2019牛客多校第六场J-Upgrading Technology(枚举+单调队列)

    Upgrading Technology 题目传送门 解题思路 对于这题,我们可以枚举一个k从0~m,表示当前我们把所有技能最少升到了k级,且至少有一个为k级. 此时我们刚好获得了前k个d[]的收益, ...

  4. Normal Equation Algorithm

    和梯度下降法一样,Normal Equation(正规方程法)算法也是一种线性回归算法(Linear Regression Algorithm).与梯度下降法通过一步步计算来逐步靠近最佳θ值不同,No ...

  5. LINUX 安装PHP GD库遇到的坑

    本文借鉴:https://www.cnblogs.com/gaohj/p/3152646.html linux下为php添加GD库的步骤如下: 一.下载 gd-.tar.gz http://www.b ...

  6. 20140923 cin.get() getline cin

    #include<iostream> #include<string> using namespace std; int main() {     string title; ...

  7. ERROR 1290 (HY000): Unknown error 1290

    如有需要可以加我Q群[308742428]大家一起讨论技术,提供有偿服务. 后面会不定时为大家更新文章,敬请期待. 喜欢的朋友可以关注下. 记录一次在连接数据库报的一个错误信息: 原因是MySQL正使 ...

  8. adb.exe端口被占用,起不来报错

    一.准备部署android功能调试时:报错 Please ensure that adb is correctly located at 'D:\ProgramFiles\eclipse_jee_ox ...

  9. shell位置参数变量

  10. Codeforces 1175E 倍增

    题意:给你n个区间和m次询问,每次询问一个区间[l, r]至少需要几个区间覆盖? 思路:如果只有一个区间,并且区间是整个取值范围的话,这是一个经典的区间覆盖问题,我们都知道贪心可以解决.现在我们需要快 ...