浅比较:
基本类型会比较值是否相等
复杂类型会比较引用地址是否相等,如===
深比较:
复杂类型递归遍历里面的每一个属性值是否相等
代码示例:
浅比较:
{a:1} === {a:1} // false
const m = {a:1};
const n = {a:1};
m === n //false
const m = {a:1};
const n = m;
m === n //true
const m = {a:1};
m === {a:1} //false
changeValue(params) {
params.a = 2;
return params;
}
const m = {a:1};
const n = changeValue(m);
m === n //true
m //{a:2}
n //{a:2}
ps: 这里`changeValue`方法直接修改了传入的参数`params`,这么做造成的后果是把 `m`的值也改变了
(因为javascript中,基本类型是传值调用,引用类型是传引用调用)
所以这种做法在`webstrom`中也会有警告,尽量不要这么做;