object.assign和...的区别
时间: 2023-04-29 17:05:54 浏览: 259
object.assign和...的区别:
1. object.assign是一个方法,用于将一个或多个源对象的属性复制到目标对象中。而...是ES6中的一个语法,用于展开对象或数组。
2. object.assign只能复制源对象的自身属性和可枚举属性,不能复制原型链上的属性。而...可以展开整个对象或数组,包括它们的原型上的属性。
3. object.assign是浅拷贝,如果源对象的属性的值是一个对象或数组,则复制的是对象的引用地址。而使用...展开对象或数组时,会创建一个新的对象或数组。
相关问题
创建Person对象 使用Object.assign()给对象添加属性name、age; 使用Object.assign()给对象方法infor(),输出对象的name和age值; 使用Object.assign()给对象添加属性sex,并设置默认值为‘male’;
在JavaScript中,你可以使用`Object.assign()`方法来合并新的或已有对象的属性到目标对象上。首先,你需要创建一个基础的`Person`对象,然后逐个添加属性和方法。下面是步骤:
1. 创建一个空的`Person`构造函数:
```javascript
function Person() {
// 默认属性初始值
}
```
2. 使用`Object.assign()`添加属性`name`和`age`:
```javascript
let person = new Person();
Object.assign(person, { name: '', age: 0 });
```
这里我们假设`name`和`age`都是可为空字符串和整数。
3. 添加一个方法`info()`,这个方法通常会在构造函数内部定义,但也可以直接作为对象的方法:
```javascript
// 如果你想在构造函数内部:
Person.prototype.info = function() {
console.log(`Name: ${this.name}, Age: ${this.age}`);
};
// 或者直接作为对象的方法(如果不在构造函数内):
person.info = function() {
console.log(`Name: ${this.name}, Age: ${this.age}`);
};
```
4. 使用`Object.assign()`添加属性`sex`并设置默认值:
```javascript
Object.assign(person, { sex: 'male' });
```
完整代码示例:
```javascript
function Person() {
this.info = function() {
console.log(`Name: ${this.name}, Age: ${this.age}`);
};
}
let person = new Person();
Object.assign(person, { name: '', age: 0 });
Object.assign(person, { sex: 'male' });
person.name = 'John Doe'; // 设置name
person.age = 30; // 设置age
person.info(); // 输出信息
```
、Object.assign()对象的拷贝Object.assign() 方法用于将所有可枚举
属性的值从一个或多个源对象复制到目标对象。它返回目标对象。
语法:
Object.assign(target, ...sources)
参数:
- target:目标对象,将源对象的属性复制到该对象。
- sources:一个或多个源对象,从这些对象中复制属性。
示例:
```
const obj1 = { a: 1 };
const obj2 = { b: 2 };
const obj3 = { c: 3 };
const newObj = Object.assign({}, obj1, obj2, obj3);
console.log(newObj); // { a: 1, b: 2, c: 3 }
```
在上面的示例中,通过Object.assign()方法将obj1、obj2和obj3的属性复制到一个新的空对象中。这样就实现了对象的拷贝。
阅读全文