没有合适的资源?快使用搜索试试~ 我知道了~
资源推荐
资源详情
资源评论
Vue父子组件传值的一些坑父子组件传值的一些坑
主要介绍了Vue父子组件传值的一些坑,帮助大家更好的理解和使用vue父子组件,感兴趣的朋友可以了解下
在用 Vue 的父子组件传值时遇到一个冷门的问题,子组件改变值后父组件的值也随之改变了,特此记录下原因和
解决方式。
再系统梳理下 JavaScript 的深拷贝与浅拷贝相关知识点。
1. 问题描述问题描述
父组件传值给子组件,子组件改变传过来的值后,父组件的值也会跟着改变。
这个问题比较冷门,平时如果对组件通信使用得比较简单,一般不会遇到。
2. 原因剖析原因剖析
核心:双向绑定
父子组件传值的时候涉及双向绑定,当传值为 object 类型时,传值之后数据源会被改变。
深拷贝与浅拷贝
下文详细讲。
3. 解决方案解决方案
我目前采用的解决办法是:
传值的时候不要直接传数据源,而是通过拷贝或者定义新变量等方式传值。
简单处理就 JSON.parse(JSON.stringify(obj)),但是这种简单粗暴的方法有其局限性。当值为 undefined、function、symbol
会在转换过程中被忽略。所以,对象值有这三种的话用这种方法会导致属性丢失。
剩下的就是自写深拷贝的工具函数,或者直接借助第三方的库函数,下面展开讲。
4. 深拷贝和浅拷贝深拷贝和浅拷贝
JavaScript中的浅拷贝与深拷贝,只是针对复杂数据类型(Object,Array)的复制问题。浅拷贝与深拷贝都可以实现在已有对
象上再生出一份的作用。但是对象的实例是存储在堆内存中然后通过一个引用值去操作对象,由此拷贝的时候就存在两种情况
了:拷贝引用和拷贝实例,这也是浅拷贝和深拷贝的区别。
下图为JavaScript复杂数据类型的浅拷贝示意图:
浅拷贝
浅拷贝是拷贝引用,拷贝后的引用都是指向同一个对象的实例,彼此之间的操作会互相影响。
值得注意的是:Object.assgin() 是浅拷贝,它只能深拷贝第一层,深层的还是浅拷贝。因为 Object.assign() 拷贝的是属性
值。假如源对象的属性值是一个对象的引用,那么它也只指向那个引用。(摘选自MDN)
MDN讲述 assign 的时候,就有一个典型的例子,这里是文章链接。
下面列举第一类浅拷贝 - 拷贝原对象的引用:
/**
* 对象的浅拷贝
*/
var obj1 = {
资源评论
weixin_38530115
- 粉丝: 9
- 资源: 960
上传资源 快速赚钱
- 我的内容管理 展开
- 我的资源 快来上传第一个资源
- 我的收益 登录查看自己的收益
- 我的积分 登录查看自己的积分
- 我的C币 登录后查看C币余额
- 我的收藏
- 我的下载
- 下载帮助
安全验证
文档复制为VIP权益,开通VIP直接复制
信息提交成功