前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >为什么vue中的data必须是一个函数?

为什么vue中的data必须是一个函数?

作者头像
用户3258338
发布2020-06-19 16:35:04
9790
发布2020-06-19 16:35:04
举报

概述

1. 引用类型与函数区别

引用类型与函数

object是引用类型,如果不用function返回,每个组件的data都是内存的同一个地址,一个数据改变了其他也改变了。

js中只有函数构成作用域(只有函数的{}构成作用域,对象的{}以及if(){}都不构成作用域),data是一个函数时,每个组件实例都有自己的作用域,每个实例相互独立,不会互相影响。

用法

JS中有三种执行上下文类型:

const MyComponent = function(){};
MyComponent.prototype.data = {
  a:1,
  b:2
}
const component1 = new MyComponent();
const component2 = new MyComponent();

component1.data.a  = component2.data.a;
component1.data.b = 5;
component2.data.b  // 5

如果两个实例引用一个对象,那么当你修改其中一个属性的时候,另外一个实例也会跟着改;

两个实例必须有自己各自的作用域才行,需要通过下列方法进行处理

const Mycomponent = function(){
  this.data = this.data();
}
Mycomponent.prototype.data = function(){
  return {
    a: 1,
    b: 2 
  }
}

这样每一个实例的data属性都是独立的,不会互相影响。

这是js本身的特性带来的,跟vue本身设计无关。

参考:

  • https://cn.vuejs.org/v2/guide/components.html#data-%E5%BF%85%E9%A1%BB%E6%98%AF%E4%B8%80%E4%B8%AA%E5%87%BD%E6%95%B0
  • https://www.jianshu.com/p/839cbef3be41
本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-06-08,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 女程序员的日常 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档