検索
ホームページウェブフロントエンドフロントエンドQ&Aes6ディープコピーのいくつかの実装方法とは何ですか?

ディープ コピーの実装方法: 1. "Object.assign({},obj)" ステートメントを使用して実装します。 2. "JSON.parse(JSON.stringify(obj))" ステートメントを使用して、 3. これを実現するには、「$.extend(true,[],arr)」ステートメントを使用します。

es6ディープコピーのいくつかの実装方法とは何ですか?

このチュートリアルの動作環境: Windows 7 システム、ECMAScript バージョン 6、Dell G3 コンピューター。

ディープ コピーとは

ディープ コピーはシャロー コピーと相対的なものです。主な違いは参照型に反映されます。コピーは単にスタック内の参照アドレスをコピーするだけなので、新しくコピーした値を変更すると、コピーされたオブジェクトも変更されますが、ディープ コピーはヒープ メモリ内に新しいオブジェクト用のスペースを作成するため、コピーされたオブジェクトは変更されません。理由もなく変更されました。

es6 でディープ コピーを実装する方法

方法 1: Object.assign を使用する

Object.assign はデフォルトでオブジェクトのディープ コピーを実行しますが、最も外側のレイヤーのディープ コピーのみを実行することに注意する必要があります。つまり、オブジェクト内にオブジェクトがネストされている場合、オブジェクトはまだ浅くコピーされています;

function cloneDeepAssign(obj){
  return Object.assign({},obj)
}

(警告: 配列コピー メソッドでは、...slice、## を使用してください) #concat コピー時にも同じ効果が得られます。最も外側のレイヤーのみが深くコピーされます)

同時に、

Object.assign が列挙可能なプロパティを対象としていることがわかります。オブジェクト自体の、および列挙不可能なプロパティの場合は効果なし;

したがって、あるレベルで単一のオブジェクトを扱うときは、シンプルで高速なこの方法を検討できます。 (試してみましたが、未定義はサポートされていません)

方法 2: JSON

これは、私たちが最も頻繁に言及する方法です。これはディープ コピー メソッドです。一般に、ほとんどのディープ コピーは JSON を使用して解決できます。本質は、JSON が新しいオブジェクトを格納するために新しいメモリを自ら構築するということです。

function cloneDeepJson(obj){
  return JSON.parse(JSON.stringify(obj))
}

ただし、注意する必要があるのは:

  • unknownsymbol を無視します;

    JSON
  • 形式文字列は
  • Function

    をサポートしておらず、シリアル化中に自動的に削除されるため、 Function にコピーできません。

  • #Map

    SetRegExpDateArrayBuffer# など# # およびその他の組み込み型はシリアル化中に失われます;

    は循環参照オブジェクトのコピーをサポートしません; (循環参照はオブジェクト内の特定の属性として大まかに理解できます)値はそれ自体です)
  • 方法 3: jQuery の
$.extend()

<pre class='brush:php;toolbar:false;'>var array = [1,2,3,4]; var newArray = $.extend(true,[],array);</pre> を使用する欠点は、jQuery ライブラリも導入する必要があるため、一般的には使用されないことです。

[関連する推奨事項:

JavaScript ビデオ チュートリアル

Web フロントエンド ]

以上がes6ディープコピーのいくつかの実装方法とは何ですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
es6怎么判断是否为数组es6怎么判断是否为数组Apr 25, 2022 pm 06:43 PM

在es6中,可以利用“Array.isArray()”方法判断对象是否为数组,若判断的对象是数组,返回的结果是true,若判断对象不是数组,返回的结果是false,语法为“Array.isArray(需要检测的js对象)”。

es6中遍历跟迭代的区别是什么es6中遍历跟迭代的区别是什么Apr 26, 2022 pm 02:57 PM

es6中遍历跟迭代的区别是:遍历强调的是要把整个数据依次全部取出来,是访问数据结构的所有元素;而迭代虽然也是依次取出数据,但是并不保证取多少,也不保证把所有的数据取完,是遍历的一种形式。

es6中怎么判断两个对象是否相等es6中怎么判断两个对象是否相等Apr 19, 2022 pm 03:34 PM

在es6中,可用Object对象的is()方法来判断两个对象是否相等,该方法检测两个变量的值是否为同一个值,判断两个对象的引用地址是否一致,语法“Object.is(对象1,对象2)”;该方法会返回布尔值,若返回true则表示两个对象相等。

es6怎么将数字转为字符串es6怎么将数字转为字符串Apr 19, 2022 pm 06:38 PM

转换方法:1、利用“+”给数字拼接一个空字符,语法“数字+""”;2、使用String(),可把对象的值转换为字符串,语法“String(数字对象)”;3、用toString(),可返回数字的字符串表示,语法“数字.toString()”。

sort排序是es6中的吗sort排序是es6中的吗Apr 25, 2022 pm 03:30 PM

sort排序是es6中的;sort排序是es6中用于对数组的元素进行排序的方法,该方法默认不传参,按照字符编码顺序进行排序,排序顺序可以是字母或数字,并按升序或降序,语法为“array.sort(callback(a,b))”。

es6中assign的用法是什么es6中assign的用法是什么May 05, 2022 pm 02:25 PM

在es6中,assign用于对象的合并,可以将源对象的所有可枚举属性复制到目标对象;若目标对象与源对象有同名属性,或多个源对象有同名属性,则后面的属性会覆盖前面的属性,语法为“Object.assign(...)”

es6怎么改变数组数据es6怎么改变数组数据Apr 26, 2022 am 10:08 AM

改变方法:1、利用splice()方法修改,该方法可以直接修改原数组的内容,语法为“数组.splice(开始位置,修改个数,修改后的值)”;2、利用下标访问数组元素,并重新赋值来修改数组数据,语法为“数组[下标值]=修改后的值;”。

import as在es6中的用法是什么import as在es6中的用法是什么Apr 25, 2022 pm 05:19 PM

在es6中,import as用于将若干export导出的内容组合成一个对象返回;ES6的模块化分为导出与导入两个模块,该方法能够将所有的导出内容包裹到指定对象中,语法为“import * as 对象 from ...”。

See all articles

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

MantisBT

MantisBT

Mantis は、製品の欠陥追跡を支援するために設計された、導入が簡単な Web ベースの欠陥追跡ツールです。 PHP、MySQL、Web サーバーが必要です。デモおよびホスティング サービスをチェックしてください。

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

強力な PHP 統合開発環境

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

DVWA

DVWA

Damn Vulnerable Web App (DVWA) は、非常に脆弱な PHP/MySQL Web アプリケーションです。その主な目的は、セキュリティ専門家が法的環境でスキルとツールをテストするのに役立ち、Web 開発者が Web アプリケーションを保護するプロセスをより深く理解できるようにし、教師/生徒が教室環境で Web アプリケーションを教え/学習できるようにすることです。安全。 DVWA の目標は、シンプルでわかりやすいインターフェイスを通じて、さまざまな難易度で最も一般的な Web 脆弱性のいくつかを実践することです。このソフトウェアは、