我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Proxy的不可变数据优点及使用方法是什么

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Proxy的不可变数据优点及使用方法是什么

这篇文章主要介绍“Proxy的不可变数据优点及使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Proxy的不可变数据优点及使用方法是什么”文章能帮助大家解决问题。

可变数据

  • 对象被赋值后,更改对象,两个都会改变,因为其引用着相同的地址,我们称这为可变对象

  • 所以这会造成意想不到的修改

  • React 要求本地组件的状态保持不可变性,Redux 同样要求全局状态保持不可变

不可变数据(Immutable Data)

  • Immutable.js 中 对 Immutable 对象 增删改查都会返回一个全新的 Immutable 对象,保证旧数据的可用不变

  • Immutable 使用了结构共享,即对象树中的节点改变只会影响自己和其父节点,其他节点共享

优点

  • 保护数据意外更改,减少bug

  • 方便跟踪数据变更,便于排错

实现一:独立方法

  • 调用麻烦

function updateData(obj, key, value) {  return {    ...obj,    [key]: value  };}const obj = {  name: "云牧"};const newObj = updateData(obj, "name", "黛玉");console.log(newObj); // { name: '黛玉' }console.log(obj); // { name: '云牧' }

实现二:自定义对象

  • 自定义新的对象类型,对其操作细节封装在其内部

  • 著名的 immutable-js,就是这个思路,定义了ListStackMapOrderedMapSetOrderedSetRecord 这么多对象

class MyObject {  constructor(obj = {}) {    this.obj = { ...obj };  }  get(name) {    return this.obj[name];  }  set(name, value) {    return new MyObject({      ...this.obj,      [name]: value    });  }}const obj = new MyObject({  name: "云牧"});const newObj = obj.set("name", "黛玉");console.log(newObj); // MyObject { obj: { name: '黛玉' } }console.log(obj); // MyObject { obj: { name: '云牧' } }

实现三:函数 + 复制

  • 函数调用产生新对象,对其新对象操作之后返回

  • 性能损耗比较大

function produce(obj, recipe) {  const newObj = { ...obj };  recipe(newObj);  return newObj;}const obj = {  name: "云牧"};const newObj = produce(obj, draft => {  draft.name = "黛玉";});console.log(newObj); // { name: '黛玉' }console.log(obj); // { name: '云牧' }

实现四:Proxy代理

function produce(obj, recipe) {  const state = {    base: obj, // 基础对象    copy: {}, // 被更改后的对象    draft: {}, // 代理对象    currentKey: 0 // 当前操作的key  };  const handlerItem = {    get(target, property, receiver) {      // 如果更改后的对象存在则使用copy      if (state.copy[state.currentKey]) {        return state.copy[state.currentKey][property];      }      return state.base[state.currentKey][property];    },    set(target, property, value, receiver) {      Reflect.set(state.copy[state.currentKey], property, value);    }  };  const handler = {    get(target, property, receiver) {      state.currentKey = property;      if (!state.draft[property]) {        const val = { ...state.base[property] };        const proxy = new Proxy(val, handlerItem);        state.draft[property] = proxy;        state.copy[property] = val;      }      return state.draft[property];    },    set(target, property, value, receiver) {      return Reflect.set(state.copy, property, value);    }  };  const proxyObj = new Proxy(obj, handler);  recipe(proxyObj);  return proxyObj;}const arrObj = Array.from({ length: 100 }, (v, index) => ({ name: "云牧" + index }));const newObj = produce(arrObj, draft => {  draft[50].name = "黛玉";});console.log(newObj[50].name); // 黛玉console.log(arrObj[50].name); // 云牧50

实现五:第三方不可变对象

  • JS没有不可变结构,我们一般可以使用 Immutable.jsimmerjs

  • Immutable.js 需要学习他的数据格式操作,且其不可变数据需要 toJS 才能得到原生对象,心智负担大

  • immerjs 则没有这方面的问题,且体积更为小巧

关于“Proxy的不可变数据优点及使用方法是什么”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识,可以关注编程网行业资讯频道,小编每天都会为大家更新不同的知识点。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Proxy的不可变数据优点及使用方法是什么

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Proxy的不可变数据优点及使用方法是什么

这篇文章主要介绍“Proxy的不可变数据优点及使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Proxy的不可变数据优点及使用方法是什么”文章能帮助大家解决问题。可变数据对象被赋值后,更
2023-07-05

Proxy的不可变数据优点及使用详解

这篇文章主要为大家介绍了Proxy的不可变数据优点及使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
2023-03-02

maven优缺点及使用方法是什么

本篇内容主要讲解“maven优缺点及使用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“maven优缺点及使用方法是什么”吧!1.什么是maven:maven是Java平台下的一款项目构
2023-07-05

SQL变量创建及使用的方法是什么

在 SQL 中,可以使用以下方法来创建和使用变量:创建变量:使用 DECLARE 语句来定义一个变量,并为其指定数据类型和初始值。例如:DECLARE @myVariable INT = 10;设置变量的值:使用 SET 语句来给变量赋值。
SQL变量创建及使用的方法是什么
2024-04-09

PostgreSQL数据库性能调优的注意点及pg数据库性能优化方法是什么

本篇内容主要讲解“PostgreSQL数据库性能调优的注意点及pg数据库性能优化方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“PostgreSQL数据库性能调优的注意点及pg数据库性能
2023-03-20

C语言可变参数使用与内存管理的方法是什么

这篇“C语言可变参数使用与内存管理的方法是什么”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“C语言可变参数使用与内存管理的方
2023-07-04

ADO.NET数据库命令及其使用方法是什么

这篇文章将为大家详细讲解有关ADO.NET数据库命令及其使用方法是什么,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。下面介绍ADO.NET数据库的相关创建维护工作:建立一个到ADO.NET数
2023-06-17

smarty模板的数据变量有哪些以及调用方法是什么

本篇内容主要讲解“smarty模板的数据变量有哪些以及调用方法是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“smarty模板的数据变量有哪些以及调用方法是什么”吧! 定义:模板变量,即在模
2023-06-07

​Aurora数据库的使用方法是什么

Aurora数据库:高性能云关系型数据库Aurora数据库是一种与MySQL和PostgreSQL兼容的关系型数据库服务,由AWS提供。它专为云环境而设计,提供了卓越的高性能、可扩展性、可靠性和与业界标准兼容性。Aurora数据库使用按需扩展、多可用区部署和自动故障切换功能来确保高可用性并优化成本。其最佳实践包括选择合适的实例类型、使用自动扩展和监视和优化。此外,它还提供了附加功能,如AuroraServerless、AuroraGlobalDatabase和AuroraDataAPI。Aurora数据库
​Aurora数据库的使用方法是什么
2024-04-12

mysql索引的优劣势是什么以及使用方法

本篇内容主要讲解“mysql索引的优劣势是什么以及使用方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“mysql索引的优劣势是什么以及使用方法”吧!一、索引的优劣势优点:可以快速的检索 、可
2023-06-08

Laravel使用多数据库的方法是什么

这篇文章主要讲解了“Laravel使用多数据库的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Laravel使用多数据库的方法是什么”吧! 使用
2023-06-25

Java连接PostgreSql数据库及基本使用方法是什么

这篇文章主要介绍“Java连接PostgreSql数据库及基本使用方法是什么”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“Java连接PostgreSql数据库及基本使用方法是什么”文章能帮助大家解
2023-07-05

Python爬取天气数据及可视化分析的方法是什么

这篇文章主要讲解了“Python爬取天气数据及可视化分析的方法是什么”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Python爬取天气数据及可视化分析的方法是什么”吧!1、数据获取请求网站链
2023-07-06

sql数据库启动不了的原因及解决方法是什么

SQL数据库启动不了的原因及解决方法可能有很多,以下是一些常见的原因及解决方法:1. 数据库服务未启动:检查数据库服务是否已启动,可以在命令行中输入"services.msc"查看并启动数据库服务。2. 数据库配置错误:检查数据库配置文件是
2023-09-04

randint函数用不了的原因及解决方法是什么

randint函数用不了的原因可能是因为没有正确导入random模块。要使用randint函数,需要先导入random模块。解决方法是在代码中添加以下导入语句:```pythonimport random```然后就可以使用random模块
2023-08-11

SQL数据库连接不上的原因及解决方法是什么

SQL数据库连接不上的原因及解决方法可能有以下几种:1. 数据库服务未启动或停止:查看数据库服务是否已启动,如果未启动,需要启动数据库服务。2. 数据库连接配置错误:检查数据库连接的配置信息,确保用户名、密码、主机地址、端口等配置项正确。3
2023-09-22

云服务器数据库使用的方法是什么

云服务器上的数据库使用方法可以分为以下几步:1. 选择合适的云服务提供商,并注册账号。2. 登录云服务提供商的控制台,创建一个云服务器实例。3. 连接到云服务器,并安装数据库软件(如MySQL、PostgreSQL等)。4. 配置数据库的相
2023-09-13

云服务器数据库使用的方法是什么

云服务器数据库使用指南云服务器数据库提供了强大的数据管理功能。本文指南涵盖了数据库选择、架构设计、安全、性能优化、管理和迁移等关键方面。通过遵循这些步骤,您可以确保云服务器数据库的性能、效率和安全性。
云服务器数据库使用的方法是什么
2024-04-10

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录