ReactJs的Hooks简介

栏目: 服务器 · 发布时间: 6年前

内容简介:在ReactConf上,React团队提出了一种使用React实现交互式组件的新方法,称为他们发布了一个开始准备工作:

在ReactConf上,React团队提出了一种使用React实现交互式组件的新方法,称为 Hooks

他们发布了一个 RFC版本, 在本文中,我们将研究如何实现这样的功能。

开始准备工作:

npx create-react-app react-hooks

cd react-hooks

npm i react@next react-dom@next

npm start

让我们创建一个新组件signin.js:

<b>import</b> React from 'react';

function Signin(props) {
    <b>return</b> <button
        onClick={props.isSignin ? props.Signout : props.Signin} >
        {props.isSignin ? <font>"Signout"</font><font> : </font><font>"Sign in"</font><font>}</button>
}


export <b>default</b> Signin;
</font>

counter.js

<b>import</b> React from 'react';

export <b>default</b> (props) => {

    <b>return</b> (
        <div>
        <h1> {props.value}</h1>
        <button onClick={props.Increment} >Increment</button>
        <button onClick={props.Decrement} >Decrement</button>
        </div>
    )

}

Hooks钩子是一种帮助我们使用react特征的功能

例如,在下面的代码中,useState钩子用于在功能组件中添加状态。

App.js

<b>import</b> React, { useState } from 'react';
<b>import</b> './App.css';
<b>import</b> Signin from './signin';
<b>import</b> Counter from './counter';

function App(props) {

   console.log(useState(0));

  <b>return</b> (
    <div className=<font>"App"</font><font>>
      <header className=</font><font>"App-header"</font><font>>
      </header>
    </div>
  );

}

export <b>default</b> App;
</font>

在上面的代码中,我们通过日志输出初始状态0的useState钩子。

useState挂钩返回具有两个元素的数组,这两个元素是当前状态和用于更新状态的函数。让我们使用数组解构的两个元素。

<b>import</b> React, { useState } from 'react';
<b>import</b> './App.css';
<b>import</b> Signin from './signin';
<b>import</b> Counter from './counter';

function App(props) {

  <b>const</b> [value, Setvalue] = useState(0);

  function Incvalue() {
    <b>return</b> Setvalue(value + 1)
  }

  function Decvalue() {
    <b>return</b> Setvalue(value - 1)
  }

  <b>return</b> (
    <div className=<font>"App"</font><font>>
      <header className=</font><font>"App-header"</font><font>>
        <Counter value={value} Increment={Incvalue} Decrement={Decvalue} />
      </header>
    </div>
  );

}

export <b>default</b> App;
<p>
</font>

这里使用一个简单的函数调用useState,useState钩子用于在功能组件中添加状态。我们能获得当前状态,我们可以更改状态,使用新状态值重新渲染组件。Incvalue和Decvalue函数能够改变value的数值状态。

自定义React钩子

自定义反应钩只是javascript函数,以“use”一词开头。

让我们创建自己的反应自定义钩子。

status.js

<b>import</b> { useState } from 'react';

function useSigninStatus(status) {

    <b>const</b> [isSignin, setSignin] = useState(status);

    function Signin() {
        setSignin(<b>true</b>)
    }

    function Signout() {
        setSignin(false)
    }
    <b>return</b> {
        isSignin,
        Signin,
        Signout,
    }
}

export <b>default</b> useSigninStatus;

<p>

如何使用自定义反应钩?以下代码是两种钩子一起使用

<b>import</b> React, { useState, useEffect } from 'react';
<b>import</b> './App.css';
<b>import</b> Signin from './signin';
<b>import</b> Counter from './counter';
<b>import</b> useSigninStatus from './status';

function App(props) {

  <b>const</b> [value, Setvalue] = useState(0);

  let status = useSigninStatus(false);

  function Incvalue() {
    <b>return</b> Setvalue(value + 1)
  }

  function Decvalue() {
    <b>return</b> Setvalue(value - 1)
  }

  <b>return</b> (
    <div className=<font>"App"</font><font>>
      <header className=</font><font>"App-header"</font><font>>
        <Signin {...status} />
        <Counter isSignin={status.isSignin} value={value} Increment={Incvalue} 
         Decrement={Decvalue} />
      </header>
    </div>
  );

}

export <b>default</b> App;
<p>
</font>

源码: 代码库

实际的钩子内部函数如下所示,只是原理展示:

let globalHooks;
function useState(defaultValue) {
  let hookData = globalHooks.get(useState);

  <b>if</b> (!hookData) hookData = { calls: 0, store: [] };

  <b>if</b> (hookData.store[hookData.calls] === undefined)
    hookData.store[hookData.calls] = defaultValue;

  let value = hookData.store[hookData.calls];

  let calls = hookData.calls;
  let setValue = function(newValue) {
    hookData.store[calls] = newValue;
    hookData.render();
  };

  hookData.calls += 1;
  globalHooks.set(useState, hookData);

  <b>return</b> [value, setValue];
}

一步步分析:

  • 在第一次调用时应该返回defaultValue。
  • 它试图从globalHooks全局变量中获取最后一次运行的状态。在调用组件函数之前通过run函数设置Map对象。Map应该有上次运行后的数据,否则需要创建自己的数据hookData。
  • hookData.store是一个数组,用于存储上次调用的hookData.calls值,该值用于跟踪此函数被我们的组件调用的程度。
  • 通过hookData.store[hookData.calls],我们可以抓住调用的最后一个存储值; 如果它不存在我们必须使用defaultValue。
  • setValue回调用于单击按钮时更新我们的数据值,例如。当点击一个按钮,会调用calls,因此它知道setState函数调用属于哪个calls。然后使用hookData.render回调,启动所有组件的重新呈现。
  • hookData.calls计数器增加。
  • hookData被存储在globalHooks变量中,因此组件函数返回后,可通过render函数使用。

以上所述就是小编给大家介绍的《ReactJs的Hooks简介》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

超简单!一学就懂的互联网金融

超简单!一学就懂的互联网金融

视觉图文 / 人民邮电出版社 / 2015-2-1 / 45.00元

零基础、全图解,通过130多个精辟的知识点、220多张通俗易懂的逻辑图表,让您一书在手,即可彻底看懂、玩转互联网金融从菜鸟成为达人,从新手成为互联网金融高手! 本书主要特色:最简洁的版式+最直观的图解+最实用的内容。 本书细节特色:10章专题内容详解+80多个特别提醒奉献+130多个知识点讲解+220多张图片全程图解,深度剖析互联网金融的精华之处,帮助读者在最短的时间内掌握互联网金融知......一起来看看 《超简单!一学就懂的互联网金融》 这本书的介绍吧!

HTML 压缩/解压工具
HTML 压缩/解压工具

在线压缩/解压 HTML 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

HTML 编码/解码
HTML 编码/解码

HTML 编码/解码