为了账号安全,请及时绑定邮箱和手机立即绑定

将对象赋值给变量,修改变量为什么对象没有被改变?

将对象赋值给变量,修改变量为什么对象没有被改变?

慕的地8271018 2018-07-18 13:48:09
写发布订阅的时候遇到了个问题。我在调用crop.remove()的时候清空了fns 但是打印fns还是有数据的。fns.length = 0;这样是可以清除的。fns不是也指向了this.list[key]吗?下方有打印结果let crop = {       list: {},       on(key, fn) {        if(!this.list[key]) {           this.list[key] = [];         }         this.list[key].push(fn);       },       emit(key, ...payload) {        let fns = this.list[key];        if(!fns || fns.length === 0) return;         fns.forEach(fn => {          fn.apply(this, payload);         })       },       remove(key, fn) {        let fns = this.list[key];         console.log(key);         fns = [];               }     }
查看完整描述

3 回答

?
郎朗坤

TA贡献1921条经验 获得超9个赞

有种
var a=[1];
var b=a;
b=[]
a??的感觉
同理 fns = [] 并不会使 this.list[key] 为[]

查看完整回答
反对 回复 2018-07-18
?
守着一只汪

TA贡献1872条经验 获得超4个赞

fns.length = 0 ; 之所以可以清空 是因为 你的fns = this.list[key];
fns = []; 这样不会清空this.list[key] 你可以理解成 fns = 1 一个道理 ;你是在给fns这个变量重新赋值 跟this.list[key];没关系。

查看完整回答
反对 回复 2018-07-18
  • 3 回答
  • 0 关注
  • 552 浏览

添加回答

举报

0/150
提交
取消
微信客服

购课补贴
联系客服咨询优惠详情

帮助反馈 APP下载

慕课网APP
您的移动学习伙伴

公众号

扫描二维码
关注慕课网微信公众号