IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> redux的理解和使用 -> 正文阅读

[JavaScript知识库]redux的理解和使用

请添加图片描述

工作流程

更改store中的数据

组件通过dispatch发布action命令

  const action = {
      type:"del_item"
  }
  store.dispatch(action)

当store拿到命令后它会把当前的state数据和action命令一起传给reducer
reducer深拷贝一份state数据,然后将新数据按照命令修改,并将新数据返给store

export default (state, action) => {
    if (action.type === "del_item") {
        let newState = JSON.parse(JSON.stringify(state))//深拷贝
        newState.list.splice(action.index, 1)
        return newState
    }
    return state
}

store对state数据进行更新

为什么reducer要深拷贝一下:reducer可以接受state 但是绝对不能修改state 所以要深拷贝一下

组件获取store的数据

store.getState()

组件订阅store数据

store.subscribe(this.storeChanged)

当store中的数据发生变更,则会触发store.subscribe中的this.storeChanged函数(这个函数名随便起)

action如果是函数(需要发送异步请求)应该怎么写

首先需要安装“redux-thunk”
配置store/index.js文件

import { createStore, applyMiddleware, compose } from 'redux'
import thunk from 'redux-thunk'
import reducer from "./reducer";

const composeEnhancers = window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__ ? window.__REDUX_DEVTOOLS_EXTENSION_COMPOSE__({}) : compose;

const enhancer = composeEnhancers(
    applyMiddleware(thunk),
    // other store enhancers if any
);

const store = createStore(reducer, enhancer)

export default store

配置store/actionCreators.js文件 getTodoList(函数名随便)返回不是对象而是函数(如果没有“redux-thunk”,则会报错,正常action只能是对象)
在这里插入图片描述
在组件中发送action命令,thunk会自动调用函数
在这里插入图片描述

什么是redux中间件

在这里插入图片描述

中间件是Action和Store中间执行的东西。
例如“redux-thunk”

假如action传过来的是个对象则正常传给Store然后给reducer处理
但是如果action是个函数则中间件先回把函数执行完,然后再把有用的数据dispatch给store

react-redux的使用

安装

npm install react-redux

在src/index.js如下配置

主要就是用Provider将store和子组件联系起来

import React from 'react';
import ReactDOM from 'react-dom';
import Todolist from './Todolist'
import { Provider } from 'react-redux'
import store from './store';

// Provider内部的子组件都可以获得store中的数据
const App = (
  <Provider store={store}>
    <Todolist></Todolist>
  </Provider>
)

ReactDOM.render(
  App,
  document.getElementById('root')
);

组件进行如下配置

主要就是通过 connect将组件和store链接起来

import React, { Component } from 'react'
// connect是将store和组件连接起来
import { connect } from 'react-redux'


export class Todolist extends Component {
    render() {
        return (
            <div>
                <div>
                    <input value={this.props.inputValue} onChange={this.props.inputChange}></input>
                    <button>提交</button>
                </div>
                <ul>
                    <li>12345646</li>
                </ul>
            </div>
        )
    }
}
// 规则1:将store中的数据映射到props
const mapStateToProps = (state) => {
    return {
        inputValue: state.inputValue
    }
}
// 规则2:将dispatch映射到props
const mapDispatchToProps = (dispatch) => {
    return {
        inputChange(e) {
            const action = {
                type: "input_change",
                value: e.target.value
            }
            dispatch(action)
        }
    }
}
export default connect(mapStateToProps, mapDispatchToProps)(Todolist)

store文件夹下index和reducer如下配置

store/index.js

import { createStore } from "redux";
import reducer from "./reducer"

const store = createStore(reducer)

export default store

store/reducer.js

const defaultState = {
    inputValue: 'hello',
    list: []
}

const reducer = (state = defaultState, action) => {
    if (action.type == 'input_change') {
        const newState = JSON.parse(JSON.stringify(state))
        newState.inputValue = action.value
        return newState
    }
    return state
}

export default reducer
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2022-03-15 22:23:40  更:2022-03-15 22:26:18 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/10 15:56:40-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码