第60节——使用redux-toolkit实战一个商品列表的增删查改

一、样例

img

二、需求

调用goods.js这个单例完成对goods数据的增删查改

class Goods {constructor() {const data = localStorage.getItem("qf-goods-data");this.goods = data ? JSON.parse(data) : [];}time = 500;/*** 获取商品* @returns*/getGoods() {return new Promise((resolve, reject) => {setTimeout(() => {resolve(this.goods);}, this.time);});}/*** 创建商品* @param {} params* @returns*/createGoods(params) {return new Promise((resolve, reject) => {setTimeout(() => {if (!params) {reject("不能不传");return;}console.log(params, this.goods);this.goods = [...this.goods, { ...params }];resolve("成功");this.keepData();}, this.time);});}/*** 传一个列表的下表* @param {*} index* @returns*/delGoods(index) {return new Promise((resolve, reject) => {if (typeof index !== "number") {reject("必须传数值");}const goods = [...this.goods];goods.splice(index, 1);this.goods = goods;resolve();this.keepData();});}/*** 传一个下标 在传一个数据* @param {*} index* @param {*} data* @returns*/updateGoods(index, data) {return new Promise((resolve, reject) => {if (typeof index !== "number") {reject("必须传数值");}const goods = [...this.goods];goods[index] = data;this.goods = [...goods];resolve();this.keepData();});}/*** 根据下标获取最新的数据* @param {*} index* @returns*/getGoodsDetail(index) {return new Promise((resolve, reject) => {if (typeof index !== "number") {reject("必须传数值");}resolve(this.goods[index]);});}async keepData() {const data = await this.getGoods();localStorage.setItem("qf-goods-data", JSON.stringify(data));}
}export default new Goods();

整个操作所有的逻辑放到redux中,页面只负责view层的渲染

ta", JSON.stringify(data));
}
}

export default new Goods();


### 整个操作所有的逻辑放到redux中,页面只负责view层的渲染### 按照页面上出现的功能完成代码

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/140249.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

spring6-资源操作:Resources

资源操作:Resources 1、Spring Resources概述2、Resource接口3、Resource的实现类3.1、UrlResource访问网络资源3.2、ClassPathResource 访问类路径下资源3.3、FileSystemResource 访问文件系统资源3.4、ServletContextResource3.5、InputStreamResource3.6、ByteAr…

联合体(共用体)

1. 联合类型的定义 联合也是一种特殊的自定义类型。 这种类型定义的变量也包含一系列的成员,特征是这些成员公用同一块空间。 2.联合大小的计算 联合的大小 至少是最大成员的大小 。 当最大成员大小不是最大对齐数的整数倍的时候,就要对 齐到最大对齐数…

【AI视野·今日CV 计算机视觉论文速览 第268期】Mon, 16 Oct 2023

AI视野今日CS.CV 计算机视觉论文速览 Mon, 16 Oct 2023 Totally 61 papers 👉上期速览✈更多精彩请移步主页 Daily Computer Vision Papers Vision-by-Language for Training-Free Compositional Image Retrieval Authors Shyamgopal Karthik, Karsten Roth, Massi…

C#中List、Dictionary、HashSet用法以及区别

前言 在C#编程中,List、Dictionary和HashSet是常用的集合类型,它们都有自己的特点和适用场景。本篇博客将介绍它们的用法、区别及常见操作。深入了解这些集合类型,能够帮助我们更好地组织和处理数据。 1. List: List是一个有序可重复集合,可…

SpringBoot实战(二十五)集成 Shiro

目录 一、Shiro 简介1.1 Shiro 定义1.2 Shiro 核心组件1.3 Shiro 认证过程 二、SpringBoot集成2.1 集成思路2.2 Maven依赖2.3 自定义 Realm2.4 Shiro 配置类2.5 静态资源映射2.6 AuthController2.7 User 实体2.8 用户接口类2.9 用户接口实现类2.10 OrderController(…

stable diffusion和midjourney哪个好

midjourney和stable diffusion哪个好?midjourney和stable diffusion的区别?那么今天就从这2款软件入手,来探索一下他们的功能的各项区别吧,让你选择更适合你的一款ai软件。 截至目前,我们目睹了生成式人工智能工具的在…

CUDA编程入门系列(二) GPU硬件架构综述

一、Fermi GPU Fermi GPU如下图所示,由16个SM(stream multiprocessor)组成,不同的SM之间通过L2 Cache和全局内存进行相连。整个架构大致分为两个层次,①总体架构由多个SM组成 ②每个SM由多个SP core(stream…

logback服务器日志删除原理分析

查看以下的logback官方文档 Chapter 4: Appendershttps://logback.qos.ch/manual/appenders.html 按文档说明,maxHistory是设置保存归档日志的最大数量,该数量的单位受到fileNamePattern里的值%d控制,如果有多个%d,只能有一个主%d&#xff0…

项目管理与SSM框架(二)| Spring

Spring简介 Spring是一个开源框架,为简化企业级开发而生。它以IOC(控制反转)和AOP(面向切面)为思想内核,提供了控制层 SpringMVC、数据层SpringData、服务层事务管理等众多技术,并可以整合众多…

第0章:怎么入手tensorflow

近年来人工智能的火爆吸引了很多人,网上相关的热门课程报名的人很多,但是坚持下去的人却少。那些晦涩的原理没有一定知识的积累很难能理解。 如果你对人工智能感兴趣,且想利用人工智能去实现某项功能,而不是对人工智能本身感兴趣&…

Vue3响应式原理初探

vue3响应式原理初探 为什么要使用proxy取代defineProperty使用proxy如何完成依赖收集呢? 为什么要使用proxy取代defineProperty 原因1:defineproperty无法检测到原本不存在的属性。打个🌰 new Vue({data(){return {name:wxs,age:25}}})在vue…