ホームページ > ウェブフロントエンド > jsチュートリアル > React+Storeonの状態管理手法についての簡単な説明

React+Storeonの状態管理手法についての簡単な説明

青灯夜游
リリース: 2021-04-15 12:48:26
転載
2605 人が閲覧しました

この記事では、React でイベント駆動型の状態管理を使用する方法を紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

React+Storeonの状態管理手法についての簡単な説明

フックが React に導入されて以来、アプリケーションの状態管理では Context API と Hook ライブラリが一緒に使用されてきました。ただし、Context API とフック (フックベースの状態管理ライブラリの多くが構築されている) を組み合わせるのは、大規模なアプリケーションでは効率的ではない可能性があります。

コンポーネントで使用する前に、状態とそのメソッドにアクセスできるようにカスタム フックを作成する必要があるため、実際の開発では面倒です。これでは、フックの本当の目的である単純さが損なわれます。しかし、小規模なアプリケーションの場合、Redux は重すぎるように思えるかもしれません。

今日は、Context API の代替手段である Storeon について説明します。 Storeon は、Redux と同様に機能する、React 用の小さなイベント駆動型の状態管理ライブラリです。 Redux DevTools を使用して、状態の操作を表示および視覚化します。 Storeon は内部で Context API を使用して状態を管理し、状態操作にイベント駆動型のアプローチを採用しています。

[関連チュートリアルの推奨事項: React ビデオ チュートリアル ]

Store

store は、アプリケーション状態コレクションに保存されているデータです。 。これは、Storeon ライブラリからインポートされた createStoreon() 関数を通じて作成されます。

createStoreon() 関数はモジュールのリストを受け取ります。各モジュールは、store パラメーターを受け取り、そのイベント リスナーをバインドする関数です。ストアの例を次に示します。

import { createStoreon } from 'storeon/react'
// todos module
const todos = store => {
  store.on(event, callback)
}

export default const store = createStoreon([todos])
ログイン後にコピー

モジュール性

Storeon のストアはモジュール式です。つまり、独立して定義され、フックやフックにバインドされません。成分。各状態とその動作方法はモジュールと呼ばれる関数で定義されます。これらのモジュールは createStoreon() 関数に渡され、グローバル ストアとして登録されます。

store には 3 つのメソッドがあります:

  • store.get() – 状態内の現在のデータを取得するために使用されます。

  • store.on(event, callback) – 指定されたイベント名にイベント リスナーを登録するために使用されます。

  • store.dispatch(event, data) – イベントを発行し、定義されたイベント要件に基づいてオプションのデータを渡すために使用されます。

Events

Storeon はイベントベースの状態管理ライブラリであり、状態の変更は状態モジュールで定義されたイベントによって発行されます。 Storeon には 3 つの組み込みイベントがあり、@ で始まります。他のイベントは、@ プレフィックスなしで定義されます。 3 つの組み込みイベントは次のとおりです。

  • @init – このイベントは、アプリの読み込み時に発生します。これは、アプリの初期状態を設定し、渡されたコールバック内のあらゆるものを実行するために使用されます。

  • @dispatch – このイベントは、新しいアクションが発生するたびに発生します。これはデバッグに役立ちます。

  • @changed – このイベントは、アプリケーションの状態が変化したときに発生します。

: store.on(event, callback) は、モジュールにイベント リスナーを追加するために使用されます。

デモ プログラム

Storeon でアプリケーションの状態操作を実行する方法をデモンストレーションするために、簡単なメモ プログラムを構築します。 Storeon の別のパッケージも状態データを localStorage に保存するために使用されます。

JavaScript と React の基本的な知識があることを前提としています。この記事で使用されているコードは、https://github.com/Youngestde... で見つけることができます。

セットアップ

本題に入る前に、プロジェクトの構造と、Notes プログラムに必要な依存関係のインストールについて概要を説明します。まずはプロジェクトフォルダーを作成します。

mkdir storeon-app && cd storeon-app
mkdir {src,public,src/Components}
touch public/{index.html, style.css} && touch src/{index,store,Components/Notes}.js
ログイン後にコピー

次に、ディレクトリを初期化し、必要な依存関係をインストールします。

npm init -y
npm i react react-dom react-scripts storeon @storeon/localstorage uuidv4
ログイン後にコピー

次のステップでは、親コンポーネントを index.js ファイルに書き込みます。

index.js

このファイルは、メモ コンポーネントのレンダリングを担当します。まず必要なパッケージをインポートします。

import React from 'react'
import { render } from 'react-dom';

function App() {
  return (
    <>
      Hello!
    </>
  );
}
const root = document.getElementById(&#39;root&#39;);
render(<App />, root);
ログイン後にコピー

次に、初期化と状態の操作のためのコードを store.js に記述してストアを構築します。

store.js

このファイルは、アプリケーション内の状態とその後の状態管理操作を処理します。状態を保存し、操作上の変更を処理するイベントをサポートするモジュールを作成する必要があります。

まず、createStoreon メソッドと一意のランダム ID ジェネレーター UUID を Storeon からインポートします。

createStoreon メソッドは、状態をグローバル ストアに登録する役割を果たします。

import { createStoreon } from &#39;storeon&#39;;
import { v4 as uuidv4 } from &#39;uuid&#39;
import { persistState } from &#39;@storeon/localstorage&#39;;

let note = store => {}
ログイン後にコピー

ステータスを配列変数 notes に保存します。この配列変数には、次の形式のメモが含まれます:

{
  id: &#39;note id&#39;,
  item: &#39;note item&#39;
},
ログイン後にコピー

接下来,我们将用两个注释(在首次启动程序时会显示)来初始化状态,从而首先填充注释模块。然后,定义状态事件。

let note = store => {
  store.on(&#39;@init&#39;, () => ({
    notes: [
      { id: uuidv4(), item: &#39;Storeon is a React state management library and unlike other state management libraries that use Context, it utilizes an event-driven approach like Redux.&#39; },
      { id: uuidv4(), item: &#39;This is a really short note. I have begun to study the basic concepts of technical writing and I&#39;\&#39;m optimistic about becoming one of the best technical writers.&#39; },
    ]
  });
  store.on(&#39;addNote&#39;, ({ notes }, note) => {
    return {
      notes: [...notes, { id: uuidv4(), item: note }],
    }
  });
  store.on(&#39;deleteNote&#39;, ({ notes }, id) => ({
    notes: notes.filter(note => note.id !== id),
  });
}
ログイン後にコピー

在上面的代码中,我们定义了状态,并用两个简短的注释填充了状态,并定义了两个事件和一个从 dispatch(event, data) 函数发出事件后将会执行的回调函数。

addNote 事件中,我们返回添加了新 note 的更新后的状态对象,在 deleteNote 事件中把 ID 传递给调度方法的 note 过滤掉。

最后,把模块分配给可导出变量 store ,将其注册为全局 store,以便稍后将其导入到上下文 provider 中,并将状态存储在 localStorage 中。

const store = createStoreon([
  notes,
  // Store state in localStorage
  persistState([&#39;notes&#39;]),
]);
export default store;
ログイン後にコピー

接下来,在 Notes.js 中编写 Notes 应用组件。

Notes.js

此文件包含 Notes 程序的组件。我们将从导入依赖项开始。

import React from &#39;react&#39;;
import { useStoreon } from &#39;storeon/react&#39;;
ログイン後にコピー

接下来,编写组件。

const Notes = () => {
  const { dispatch, notes } = useStoreon(&#39;notes&#39;);
  const [ value, setValue ] = React.useState(&#39;&#39;); 
}
ログイン後にコピー

在上面的代码的第二行中,useStoreon() hook 的返回值设置为可破坏的对象。 useStoreon() hook 使用模块名称作为其参数,并返回状态和调度方法以发出事件。

接下来定义在组件中发出状态定义事件的方法 。

const Notes = () => {
...
  const deleteNote = id => {
    dispatch(&#39;deleteNote&#39;, id)
  };
  const submit = () => {
    dispatch(&#39;addNote&#39;, value);
    setValue(&#39;&#39;);
  };
  const handleInput = e => {
    setValue(e.target.value);
  };
}
ログイン後にコピー

Let’s review the three methods we defined the above:
让我们回顾一下上面定义的三种方法:

  • deleteNote(id) – 此方法在触发时调度 deleteNote 事件。

  • submit() – 该方法通过传递输入状态的值来调度 addNote 事件,该状态在 Notes 组件中本地定义。

  • handleInput() – 此方法将本地状态的值设置为用户输入。

Next, we’ll build the main interface of our app and export it.
接下来,我们将构建应用程序的主界面并将其导出。

const Notes = () => {
  ...
  return (
    <section>
      <header>Quick Notes</header>

      <div className=&#39;addNote&#39;>
        <textarea onChange={handleInput} value={value} />
        <button onClick={() => submit()}> Add A Note </button>
      </div>

      <ul>
        {notes.map(note => (
          <li key={note.id}>
            <div className=&#39;todo&#39;>
              <p>{note.item}</p>
              <button onClick={() => deleteNote(note.id)}>Delete note</button>
            </div>
          </li>
        ))}
      </ul>
    </section>
  );
}
ログイン後にコピー

这样就构成了我们的 Notes 组件。接下来为我们的应用和 index.html 文件编写样式表。

index.html

<!DOCTYPE html>
<html>

<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <meta http-equiv="X-UA-Compatible" content="ie=edge">
    <link rel="stylesheet" href="style.css">
    <title>Storeon Todo App</title>
</head>

<body>
    <div id="root"></div>
</body>

</html>
ログイン後にコピー

接下来,填充我们的 style.css 文件。

style.css

* {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

section {
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
  width: 300px;
  margin: auto;
}

header {
  text-align: center;
  font-size: 24px;
  line-height: 40px;
}

ul {
  display: block;
}

.todo {
  display: block;
  margin: 12px 0;
  width: 300px;
  padding: 16px;
  box-shadow: 0 8px 12px 0 rgba(0, 0, 0, 0.3);
  transition: 0.2s;
  word-break: break-word;
}

li {
  list-style-type: none;
  display: block;
}

textarea {
  border: 1px double;
  box-shadow: 1px 1px 1px #999;
  height: 100px;
  margin: 12px 0;
  width: 100%;
  padding: 5px 10px;
}

button {
  margin: 8px 0;
  border-radius: 5px;
  padding: 10px 25px;
}

.box:hover {
  box-shadow: 0 8px 16px 0 rgba(0, 0, 0, 0.2);
}
ログイン後にコピー

运行

现在我们已经成功编写了组件和样式表,但是还没有更新 index.js 中的父组件来渲染 Notes 组件。接下来让我们渲染 Notes 组件。

index.js

要访问我们的全局 store,必须导入 store 和 Storeon store 上下文组件。我们还将导入 notes 组件来进行渲染。

用以下代码替换组件的内容:

import React from &#39;react&#39;;
import { render } from &#39;react-dom&#39;;
import { StoreContext } from &#39;storeon/react&#39;;
import Notes from &#39;./Components/Notes&#39;;
import store from &#39;../src/store&#39;;

function App() {
  return (
    <>
      <StoreContext.Provider value={store}>
        <Notes />
      </StoreContext.Provider>
    </>
  );
}

const root = document.getElementById(&#39;root&#39;);
render(<App />, root);
ログイン後にコピー

在第 8-10 行,调用 store 上下文提供程序组件,并将 notes 组件作为使用者传递。store 上下文提供程序组件将全局 store 作为其上下文值。

接下来把 package.json 文件中的脚本部分编辑为以下内容:

"scripts": {
  "start": "react-scripts start",
}
ログイン後にコピー

然后运行我们的程序:

npm run start
ログイン後にコピー

让我们继续添加和删除注释:

React+Storeonの状態管理手法についての簡単な説明

Storeon devtools

Storeon 与 Redux 有着相似的属性,可以在 Redux DevTools 中可视化和监视状态的更改。为了可视化 Storeon 程序中的状态,我们将导入 devtools 包,并将其作为参数添加到我们 store.js 文件的 createStoreon() 方法中。

...
import { storeonDevtools } from &#39;storeon/devtools&#39;;
...
const store = createStoreon([
  ...,
  process.env.NODE_ENV !== &#39;production&#39; && storeonDevtools,
]);
ログイン後にコピー

这是用 Redux DevTools 可视化状态变化的演示:

React+Storeonの状態管理手法についての簡単な説明

结论

Storeon 是一个非常有用的状态管理库,它用事件驱动和 Redux 改编的模块化样式来管理状态。你可以在https://github.com/Youngestdev/storeon-app上找到本文中的代码。

原文地址:https://blog.logrocket.com/event-driven-state-management-in-react-using-storeon/

作者:Abdulazeez Abdulazeez Adeshina

更多编程相关知识,请访问:编程视频!!

以上がReact+Storeonの状態管理手法についての簡単な説明の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ソース:segmentfault.com
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート