当前位置: 首页 > news >正文

个人音乐网站策划书范文搜索引擎有哪些网站

个人音乐网站策划书范文,搜索引擎有哪些网站,企业微信官网入口,河南省住房和城乡建设厅一、什么是action 在 Redux 中,Action 是一个简单的 JavaScript 对象,用于描述对应应用中的某个事件(例如用户操作)所发生的变化。它包含了一个 type 属性,用于表示事件的类型,以及其他一些可选的数据。 …

一、什么是action

在 Redux 中,Action 是一个简单的 JavaScript 对象,用于描述对应应用中的某个事件(例如用户操作)所发生的变化。它包含了一个 type 属性,用于表示事件的类型,以及其他一些可选的数据。

Action 可以被 Redux Store 中的 reducer 函数捕获并处理,从而对应用的状态进行更新。通过使用 Action,可以实现可预测、可追踪和可测试的应用状态管理。

二、什么是reducer

Reducer 是 Redux 中的一个概念,它是一个纯函数,用于处理应用的状态变更。Reducer 的输入是当前状态和一个操作(action),输出是下一个状态。

在 Redux 中,所有的状态变更都必须通过发送一个 action 实现。每一个 action 都是一个描述状态变更的对象,包含了一个 type 属性和一些其他属性。当一个 action 被发送到 store,它会触发 store 对应的 reducer,使用当前状态和 action 来生成下一个状态。

三、action的基本语法

import React from 'react';
import { useSelector, useDispatch } from 'react-redux';function Counter() {const count = useSelector(state => state.count);/*调用一下useDispatch返回一个dispatch方法*/const dispatch = useDispatch();return (<div><p>Count: {count}</p>{/* 调用这个方法必须要传一个对象对象里面一般来说包含两个属性type 代表发起的操作,通过reducer 执行不同的逻辑payload 这是一个抽象意义的字段,代表传值每个type不能重复*/}<button onClick={() => dispatch({ type: 'INCREMENT' })}>+</button><button onClick={() => dispatch({ type: 'DECREMENT' })}>-</button></div>);
}export default Counter;

四、命名空间模块

使用命名空间模块管理type的值

创建一个namespace目录并创建user.js

const moduleName = "goods";const generateType = (name) => {return `${moduleName}/${name}`;
};export const SAVE = generateType("save");

四、在页面中发起一个dispatch调用对应的reducer修改数据

1、定义一个user模块,并编写更新用户名的方法

import { UPDATE_NAME } from './../namespace/user'const defaultState = {name: "李光明",age: 20,
};export const userReducer = (state = defaultState, action) => {switch (action.type) {/*** reducer模块化后命名* 一般要求全局唯一* 一般来可以采用模块名/case名的方式*/case UPDATE_NAME:return {...state, ...action.payload}default:return state;}
};

2、store.js文件中修改

/*** 由于在redux4.x 版本createStore已经被废弃* 但是 createStore 相对来说对我们了解redux有比较重要* 那么,我们就引入legacy_createStore 这个方法* 然后给他重命名redux 就可以正常使用createStore* 后面我们会着重讲新版redux的用法**/
import { legacy_createStore as createStore, combineReducers } from "redux";
import user from "./user";const rootReducer = combineReducers({user,
});// 创建 store
const store = createStore(rootReducer);// 导出 store
export default store;

3、页面中使用dispatch出发reducer修改state

import React from "react";
import { useSelector, useDispatch } from "react-redux";
import { UPDATE_NAME } from './../namespace/user'function UserInfo() {const state = useSelector((state) => state.user);const dispatch = useDispatch();return (<div><p>Name: {state.name}</p><buttononClick={() =>dispatch({type: UPDATE_NAME,name: "李四 ",})}>修改名字为李四</button></div>);
}export default UserInfo;
http://www.yidumall.com/news/102272.html

相关文章:

  • 滨江区建设局网站百度竞价推广
  • 宁波房产网上备案查询官网哈尔滨网络优化推广公司
  • 一个好的网站建设需要多少钱晚上网站推广软件免费版
  • 兰州网站制作服务电话襄阳网站推广优化技巧
  • 网站建设好怎么发布企业关键词优化价格
  • 最好链接的网站建设兰州网络推广推广机构
  • 中山市做网站创建一个网站
  • 用服务器做网站厦门seo收费
  • 烟台做网站公司短视频营销的发展趋势
  • wordpress文章图片目录简述搜索引擎优化
  • 招商广告广州网站优化
  • 求职网站开发开题报告系统优化的意义
  • 湖北网站推广技巧搜狗搜索推广
  • 注册500万公司每月交税seo网站推广费用
  • 企业营销型网站规划福建企业seo推广
  • 百度模板网站模板今日国际新闻
  • 有模板做ppt的网站有哪些qq代刷网站推广
  • 济南网站建设小程序开发重庆seo网络推广
  • xp做网站服务器网站优化的方法
  • 机加工外协加工网seo优化及推广如何运营
  • 家具网站 模板亚马逊查关键词排名工具
  • 仪征市企业网站建设公司竞价软件哪个好
  • 南京电商网站建设如何推广一个新的app
  • 深圳市招投标交易中心网站深圳网站建设的公司
  • 淄博英文网站建设信阳网站推广公司
  • 烟店网站建设今日疫情实时数据
  • wordpress 4.9.8主题seo排名培训学校
  • 网站建设书本信息厦门seo网站排名优化
  • 设计网站模板搭建网站工具
  • 芜湖市建设工程网站维护公告国际军事新闻最新消息视频