search
HomeWeb Front-endFront-end Q&AJavaScript shallow copy implementation

In JavaScript development, we often need to handle copy operations of objects or arrays. In actual development, we often encounter the need for shallow copy, that is, copying the contents of one object or array to another object or array. The copied new object or array shares part of the data with the original object or array. This article will introduce how to implement shallow copy in JavaScript.

1. What is shallow copy?

In JavaScript, objects and arrays are both reference types. When we assign an object or array to a new variable, we actually assign the reference of the original object or array to the new variable.

For example, the following code assigns an object to a new variable:

let obj1 = { name: '张三', age: 18 };
let obj2 = obj1;

In this example, obj2 and obj1 are not two Different objects, but two references pointing to the same memory address.

In actual development, we may need to copy the contents of an object or array to another object or array, in which case a shallow copy is required.

Shallow copy refers to copying only the first-level data structure of an object or array. If the object or array also contains objects or arrays, the copied new object or array will share these reference types with the original object or array. The data structure is as shown in the figure below:

JavaScript shallow copy implementation

As shown in the figure, object A contains two attributes a and b. The value of attribute b is an object B. Object B It also contains two attributes c and d. When a shallow copy is made of object A, a new object C is generated. Object C shares attributes a and b with object A. That is, the shallow copy only copies the first-level structure of object A, while object B is only referenced once. Object C and object A share object B, that is, the addresses of the two objects are the same.

2. Shallow copy implementation methods

The following will introduce several common shallow copy implementation methods in JavaScript.

  1. Manual traversal

Manually traverse the object or array, copying each attribute or element to a new object or array. This method is simple and easy to understand, and the code is highly readable. However, for objects or arrays with many nested levels, the amount of code will be very large.

function shallowCopy(obj) {
  if (Array.isArray(obj)) {
    return obj.slice();
  } else if (typeof obj === 'object' && obj !== null) {
    let newObj = {};
    for (let key in obj) {
      if (obj.hasOwnProperty(key)) {
        newObj[key] = obj[key];
      }
    }
    return newObj;
  } else {
    return obj;
  }
}

In this example, we first determine whether the object to be copied is an array or an object. If it is an array, we use the slice() method to make a shallow copy; if it is an object, we loop through the properties of the object and copy each property to a new object, and finally return the new object.

  1. Object.assign()

Object.assign() method is used to copy the properties of one or more objects to the target object , if multiple objects have the same property, the properties in subsequent objects will overwrite the properties in the previous object. Object.assign() The method will only copy the first-level data structure of the object. If the object contains reference type attributes, the new object and the original object will share these reference type attributes.

let obj1 = { name: '张三', age: 18, hobbies: ['coding', 'reading'] };
let obj2 = Object.assign({}, obj1);

In this example, we use the Object.assign() method to copy object obj1 to a new empty object and generate a new object obj2.

Note that when using the Object.assign() method, the first parameter must be the target object, and the following parameters are the source object. If the source object has the same properties, the subsequent object Properties in will overwrite properties in the previous object. If there are properties in the source object that are reference types, the copied new object will share these properties with the original object.

  1. Spread operator

The spread operator (spread operator) is a new syntax in ES6, which can be used to expand arrays or objects and copy their contents to in another array or object. The spread operator can only be used on the first-level data structure of an object or array. If the object or array contains properties of reference types, the new object or array will share these properties with the original object or array.

let arr1 = [1, 2, 3];
let arr2 = [...arr1];

let obj1 = { name: '张三', age: 18, hobbies: ['coding', 'reading'] };
let obj2 = { ...obj1 };

In this example, we use the spread operator to copy the contents of the array arr1 and object obj1 to a new array and object, generating a new array arr2 and object obj2.

The spread operator is convenient and concise to use, and the code is highly readable. However, for objects or arrays with many nested levels, the amount of code is still relatively large.

  1. Array.from()

Array.from() method is used to convert an array-like object or iterable object into a new The array can be used for shallow copy of the array.

let arr1 = [1, 2, 3];
let arr2 = Array.from(arr1);

In this example, we use the Array.from() method to convert the array arr1 into a new array arr2, implementing a shallow copy.

It should be noted that the Array.from() method can only be used for shallow copies of array-like objects or iterable objects. If you need to make a shallow copy of an object, you need to use other methods. method.

3. Summary

This article introduces the implementation of shallow copy in JavaScript, including manual traversal, Object.assign() method, spread operator and Array.from() method. In actual development, we can choose the most suitable method to perform shallow copy operations according to actual needs. It should be noted that shallow copy only copies the first-level data structure of an object or array. If the object or array contains reference type attributes, the new object or array copied by shallow copy will share these attributes with the original object or array. . If you need to implement a deep copy, you need to use other methods to operate.

The above is the detailed content of JavaScript shallow copy implementation. For more information, please follow other related articles on the PHP Chinese website!

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
What is useEffect? How do you use it to perform side effects?What is useEffect? How do you use it to perform side effects?Mar 19, 2025 pm 03:58 PM

The article discusses useEffect in React, a hook for managing side effects like data fetching and DOM manipulation in functional components. It explains usage, common side effects, and cleanup to prevent issues like memory leaks.

Explain the concept of lazy loading.Explain the concept of lazy loading.Mar 13, 2025 pm 07:47 PM

Lazy loading delays loading of content until needed, improving web performance and user experience by reducing initial load times and server load.

What are higher-order functions in JavaScript, and how can they be used to write more concise and reusable code?What are higher-order functions in JavaScript, and how can they be used to write more concise and reusable code?Mar 18, 2025 pm 01:44 PM

Higher-order functions in JavaScript enhance code conciseness, reusability, modularity, and performance through abstraction, common patterns, and optimization techniques.

How does currying work in JavaScript, and what are its benefits?How does currying work in JavaScript, and what are its benefits?Mar 18, 2025 pm 01:45 PM

The article discusses currying in JavaScript, a technique transforming multi-argument functions into single-argument function sequences. It explores currying's implementation, benefits like partial application, and practical uses, enhancing code read

How does the React reconciliation algorithm work?How does the React reconciliation algorithm work?Mar 18, 2025 pm 01:58 PM

The article explains React's reconciliation algorithm, which efficiently updates the DOM by comparing Virtual DOM trees. It discusses performance benefits, optimization techniques, and impacts on user experience.Character count: 159

How do you prevent default behavior in event handlers?How do you prevent default behavior in event handlers?Mar 19, 2025 pm 04:10 PM

Article discusses preventing default behavior in event handlers using preventDefault() method, its benefits like enhanced user experience, and potential issues like accessibility concerns.

What is useContext? How do you use it to share state between components?What is useContext? How do you use it to share state between components?Mar 19, 2025 pm 03:59 PM

The article explains useContext in React, which simplifies state management by avoiding prop drilling. It discusses benefits like centralized state and performance improvements through reduced re-renders.

What are the advantages and disadvantages of controlled and uncontrolled components?What are the advantages and disadvantages of controlled and uncontrolled components?Mar 19, 2025 pm 04:16 PM

The article discusses the advantages and disadvantages of controlled and uncontrolled components in React, focusing on aspects like predictability, performance, and use cases. It advises on factors to consider when choosing between them.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

AI Hentai Generator

AI Hentai Generator

Generate AI Hentai for free.

Hot Article

Hot Tools

MantisBT

MantisBT

Mantis is an easy-to-deploy web-based defect tracking tool designed to aid in product defect tracking. It requires PHP, MySQL and a web server. Check out our demo and hosting services.

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

Dreamweaver Mac version

Dreamweaver Mac version

Visual web development tools

Notepad++7.3.1

Notepad++7.3.1

Easy-to-use and free code editor

SublimeText3 English version

SublimeText3 English version

Recommended: Win version, supports code prompts!