React 16.7.0-alpha hooks 之整体预览

栏目: IOS · Android · 发布时间: 5年前

内容简介:转载于免费视频网www.rails365.net之前我们介绍了是一个快节奏的概述。如果你感到困惑,可以看下上面提到的介绍里的动机:

转载于免费视频网www.rails365.net

之前我们介绍了 使用hooks的原因 ,在开始介绍api之前,现在我们先来整体的预览下这些 api 。 从上篇的介绍可以知道, Hook 是向后兼容的,有 react 开发经验的你看起来会更顺畅。

是一个快节奏的概述。如果你感到困惑,可以看下上面提到的介绍里的动机:

详细说明 阅读动机 以了解我们为何将Hooks引入React。

State Hook

看下面的例子,他是一个计数器

import { useState } from 'react';

function Example() {
  // Declare a new state variable, which we'll call "count"
  const [count, setCount] = useState(0);

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() : setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}
复制代码

在这里 useState 是一个 Hook (我们将在稍后讨论这意味着什么)。可以看到,在这个函数组件里,我们向他添加一些本地状态。 React 将在重新渲染之间保留这状态。 useState 返回一对:当前状态值( count )和允许你更新状态的函数( setCount )。你可以从事件处理程序或其他位置调用此函数。这个函数类似于类中的 this.setState ,但是它不会将旧状态和新状态合并在一起。(我们将在使用State Hook中显示一个将 useStatethis.state 进行比较的示例。)

useState 的唯一参数是初始状态。 在上面的例子中,它是0,因为我们的计数器从零开始。请注意,与 this.state 不同,此处的状态不必是对象 - 尽管可以是任何你想要的。 初始状态参数仅在第一次渲染期间使用。

声明多个 state

你可以在一个组件中多次使用 State Hook

function ExampleWithManyStates() {
  const [age, setAge] = useState(42);
  const [fruit, setFruit] = useState('banana');
  const [todos, setTodos] = useState([{ text: 'Learn Hooks' }]);
  // ...
}
复制代码

数组解构语法允许我们为通过调用 useState 声明的状态变量赋予不同的名称。这些名称不是 useState API 的一部分。相反, React 假定如果多次调用 useState ,则在每次渲染期间以相同的顺序执行。我们将回到为什么这种方法有效以及何时有用。

什么是 Hook

钩子是允许从功能组件(function component)“挂钩”React状态和生命周期功能的功能。 钩子在类内部不起作用 - 它们允许你在没有类的情况下使用 React (我们 不建议 你在一夜之间重写现有组件,但如果你愿意,可以开始在新组件中使用 Hook 。)

React 提供了一些像 useState 这样的内置 Hook 。你还可以创建自定义 Hook 以在不同组件之间重用有状态行为。我们先来看看内置的 Hooks

详细说明你可以在使用State Hook中了解更多信息。

Effect Hook

你之前可能已经从 React 组件执行数据提取,订阅或手动更改 DOM 。我们将这些操作称为“副作用”(或简称为“效果”),因为它们会影响其他组件,并且在渲染过程中无法完成。

Effect Hook 中的 useEffect 增加了在功能组件执行副作用的功能。它与 React 类中的 componentDidMountcomponentDidUpdatecomponentWillUnmount 具有相同的用途,但统一为单个API。(我们将在 使用 Effect Hook 时显示将 useEffect 与这些方法进行比较的示例。)

例如,下面的组件将在 React 更新 DOM 后设置文档标题:

import { useState, useEffect } from 'react';

function Example() {
  const [count, setCount] = useState(0);

  // 类似componentDidMount 和 componentDidUpdate:
  useEffect(() : {
    // Update the document title using the browser API
    document.title = `You clicked ${count} times`;
  });

  return (
    <div>
      <p>You clicked {count} times</p>
      <button onClick={() : setCount(count + 1)}>
        Click me
      </button>
    </div>
  );
}
复制代码

当你调用 useEffect 时,你就在告诉 react 运行你的‘效果’函数当刷新对 DOM 的更改后(你可以认为是 render 之后)。 效果在组件内声明,因此可以访问其 propsstate 。默认情况下, React 在每次渲染后运行效果 - 包括第一次渲染。 (我们将更多地讨论使用effect hook与类生命周期的比较。)

Effects 还可以通过指定返回函数来清理他们。看下面的这个例子:

import { useState, useEffect } from 'react';

function FriendStatus(props) {
  const [isOnline, setIsOnline] = useState(null);

  function handleStatusChange(status) {
    setIsOnline(status.isOnline);
  }

  useEffect(() : {
    ChatAPI.subscribeToFriendStatus(props.friend.id, handleStatusChange);

    return () : {
      ChatAPI.unsubscribeFromFriendStatus(props.friend.id, handleStatusChange);
    };
  });

  if (isOnline === null) {
    return 'Loading...';
  }
  return isOnline ? 'Online' : 'Offline';
}
复制代码

在这个示例中,当组件卸载时,以及在由于后续渲染而重新运行效果之前, React 将取消订阅我们的 ChatAPI 。(如果你愿意的话,如果我们传递给 ChatAPIprops.friend.id 没有改变,有办法 告诉 React 跳过重新订阅 。)

就像使用 useState 一样, 你也可以在组件中使用多个效果:

function FriendStatusWithCounter(props) {
  const [count, setCount] = useState(0);
  useEffect(() : {
    document.title = `You clicked ${count} times`;
  });

  const [isOnline, setIsOnline] = useState(null);
  useEffect(() : {
    ChatAPI.subscribeToFriendStatus(props.friend.id, handleStatusChange);
    return () : {
      ChatAPI.unsubscribeFromFriendStatus(props.friend.id, handleStatusChange);
    };
  });

  function handleStatusChange(status) {
    setIsOnline(status.isOnline);
  }
  // ...
}
复制代码

Hooks 允许你通过哪些部分相关(例如添加和删除订阅)来组织组件中的副作用,而不是基于生命周期方法强制拆分。

详细说明你可以在使用Effect Hook中了解更多信息。

Hooks 的规则

钩子是 JavaScript 函数,但它们强加了两个额外的规则:

  • 只能在顶层调用 Hooks 。不要在循环,条件或嵌套函数中调用 Hook
  • 仅从 React 功能组件调用 Hooks 不要从常规 JavaScript 函数中调用 Hook 。 (还有另一个有效的地方叫 Hooks - 你自己的定制 Hooks 。我们马上就会了解它们。)

详细说明你可以在Rules Hook中了解更多信息。

Custom Hooks

有时,我们希望在组件之间重用一些有状态逻辑的部分。传统上,这个问题有两个流行的解决方案:高阶组件和 渲染道具Custom Hooks 允许你执行这样的操作,并且无需向树中添加更多组件。在上面我们介绍了一个调用 useStateuseEffect HooksFriendStatus 组件来订阅朋友的在线状态。假设我们还希望在另一个组件中重用此订阅逻辑。 首先,我们将这个逻辑提取到一个名为 useFriendStatus 的自定义 Hook 中:

import { useState, useEffect } from 'react';

function useFriendStatus(friendID) {
  const [isOnline, setIsOnline] = useState(null);

  function handleStatusChange(status) {
    setIsOnline(status.isOnline);
  }

  useEffect(() : {
    ChatAPI.subscribeToFriendStatus(friendID, handleStatusChange);
    return () : {
      ChatAPI.unsubscribeFromFriendStatus(friendID, handleStatusChange);
    };
  });

  return isOnline;
}
复制代码

它将 friendID 作为参数,并返回我们的朋友是否在线。 现在我们可以从两个组件中使用它:

function FriendStatus(props) {
  const isOnline = useFriendStatus(props.friend.id);

  if (isOnline === null) {
    return 'Loading...';
  }
  return isOnline ? 'Online' : 'Offline';
}
复制代码
function FriendListItem(props) {
  const isOnline = useFriendStatus(props.friend.id);

  return (
    <li style={{ color: isOnline ? 'green' : 'black' }}>
      {props.friend.name}
    </li>
  );
}
复制代码

这些组件的状态是完全独立的。 钩子是重用有状态逻辑的一种方式,而不是状态本身。 事实上,每次调用 Hook 都有一个完全隔离的状态 - 所以你甚至可以在一个组件中使用相同的自定义 Hook 两次。

custom hook 更像是一种约定而非功能。如果函数的名称以 use 开头并且它调用其他 Hook ,我们说它是一个 Custom HookuseSomething 命名约定是 linter 插件如何使用 Hooks 在代码中查找错误的。

详细说明你可以在Writing Custom Hooks中了解更多信息。

Other Hooks

你可能会发现一些不太常用的内置 Hook 很有用。例如,useContext允许订阅 React 上下文而不引入嵌套:

function Example() {
  const locale = useContext(LocaleContext);
  const theme = useContext(ThemeContext);
  // ...
}
复制代码

useReducer允许使用 reducer 管理复杂组件的本地状态:

function Todos() {
  const [todos, dispatch] = useReducer(todosReducer);
  // ...
}
复制代码

详细说明你可以在 Hooks API Reference.中了解更多信息。

本文原文档

下一章节 state前往此处


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

查看所有标签

猜你喜欢:

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

C语言进阶

C语言进阶

牟海军 / 机械工业出版社 / 2012-7 / 59.00元

C语言是编程语言中的一朵奇葩,虽已垂垂老矣,但却屹立不倒,诞生了数十年,仍然是最流行的编程语言之一。C语言看似简单,却不易吃透,想要运用好,更是需要积淀。本书是一本修炼C程序设计能力的进阶之作,它没有系统地去讲解C语言的语法和编程方法,而是只对C语言中不容易被初学者理解的重点、难点和疑点进行了细致而深入的解读,揭露了C语言中那些鲜为普通开发者所知的秘密,旨在让读者真正掌握C语言,从而编写出更高质量......一起来看看 《C语言进阶》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

Base64 编码/解码
Base64 编码/解码

Base64 编码/解码