其他分享
首页 > 其他分享> > data为什么是一个函数

data为什么是一个函数

作者:互联网

例子

const MyComponent = function() {};
MyComponent.prototype.data = {
    a: 1,
    b: 2,
}
const component1 = new MyComponent();
const component2 = new MyComponent();
 
component1.data.a === component2.data.a; // true;
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属性都是独立的,不会相互影响了.

标签:function,为什么,const,函数,实例,MyComponent,data
来源: https://blog.csdn.net/qq_45785548/article/details/122812969