| | 和原数据是否指向同一个对象 | 第一层数据为基本数据类型 | 原数据中包含的子对象 |
| — | — | — | — |
| 浅拷贝 | 否 | 不会使原数据一起改变 | 会使原数据一起改变 |
| 深拷贝 | 否 | 不会使原数据一起改变 | 不会使原数据一起改变 |
点击对Javscript中浅拷贝和深拷贝的探索和详解查看详解
=================================================================================
实现浅拷贝的方法:
-
简单赋值
-
利用 for…in循环实现浅拷贝
-
利用Object.assign()方法
实现深拷贝的方法:
-
使用递归的方式实现深拷贝
-
通过 JSON 对象实现深拷贝
-
slice()、concat()对数组进行深拷贝
点击对Javscript中浅拷贝和深拷贝的探索和详解查看详解
=============================================================================
| | 和原数据是否指向同一个对象 | 第一层数据为基本数据类型 | 原数据中包含的子对象 |
| — | — | — | — |
| 赋值 | 是 | 会使原数据一起改变 | 会使原数据一起改变 |
| 浅拷贝 | 否 | 不会使原数据一起改变 | 会使原数据一起改变 |
| 深拷贝 | 否 | 不会使原数据一起改变 | 不会使原数据一起改变 |
三者的内存图:
赋值
浅拷贝
深拷贝
点击对Javscript中浅拷贝和深拷贝的探索和详解查看详解
=================================================================================
-
首先创建了一个空对象 obj
-
将对象与构建函数通过原型链连接起来
-
将构建函数中的this绑定到新建的对象obj上
-
根据构建函数返回类型作判断,如果是原始值则被忽略,如果是返回对象,需要正常处理
======================================================================================
原型:
-
在 JavaScript 中,每当定义一个对象时候,对象中都会包含一些预定义的属性。其中每个函数对象都有一个prototype 属性,这个属性指向函数的原型对象。
-
原型对象都会自动获得一个constructor属性,这个属性是一个指向prototype属性所在函数的指针;
-
当调用构造函数创建一个新实例后,高实例对象内部将包含一个指针(内部属性_proto_),指向构造函数的原型对象;
-
原型对象的用途是包含可以由特定类型的所有实例共享的属性和方法。
原型链:
-
原型链是就是实例对象在查找属性时,如果查找不到,就会沿着__proto__去与对象关联的原型上查找,有则返回,如果找不到,就去找原型的原型,直至查到最顶层Object函数的原型,其原型对象的_proto__已经没有可以指向的上层原型,因此其值为null,返回undefind;
-
原型链是实现继承的主要方法,其基本思想就是利用原型让一个引用类型继承另一个引用类型的属性和方法;
点击对Javascript中原型和原型链的探索和详解查看详解
===================================