采纳答案成功!
向帮助你的同学说点啥吧!感谢那些助人为乐的人
如果是点击这里的随机播放全部,那么这里的sequenceList跟playList提交mutations的时候,不是已经指向了两个不同的引用了吗,那怎么currentSong变化的时候提交的addSongLyric mutation里,修改了sequenceList,playList也能跟着变化呢?我纠结的是这个时候不应该已经是两个不同的引用了吗,但是为啥好像还是指向同一个引用呢
sequenceList 和 playlist 的数组是不同的引用,但是数组内部的对象是同一份引用。
song 对象就是引用。
谢谢,我明白了,虽然两个数组指向不同,但是这两个数组内部的对象是同一份,这样的话即使是遍历其中一个数组去修改内部的对象,另一个也会跟着变化, const obj = {a: '123'}; const arr1 = [obj]; const arr2 = [obj]; arr1.map(item => { item.id = 1 // 这个时候相当于在对obj做操作,而obj是对象,是引用类型,所以虽然这边是遍历arr1,但是arr2中的obj也会跟着变化 return item }) console.log(arr1, arr2)
登录后可查看更多问答,登录/注册
慕课网明星讲师黄轶深度讲解 Vue3.0 ,提升的不止是Vue代码能力
1.2k 3
539 23
2.9k 15
1.1k 14
1.2k 13