zoukankan      html  css  js  c++  java
  • 为什么vue中data必须是一个函数

    本文从JavaScript原型链角度来解释为什么vue中的data必须是一个函数

    VUE组件中的data必须是函数

    类别引用数据类型

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

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

    例如:

     1 const MyComponent = function() {};
     2 MyComponent.prototype.data = {
     3     a: 1,
     4     b: 2
     5 }
     6 const component1 = new MyComponent();
     7 const component2 = new MyComponent();
     8  
     9 component1.data.a === component2.data.a; // true
    10 component1.data.b = 5;
    11 component2.data.b //5

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

    两个实例应该有自己各自的域才对,需要通过下面的方法进行处理

     1 const MyComponent = function() {
     2     this.data = this.data();
     3 };
     4  
     5 MyComponent.prototype.data = function() {
     6     return {
     7         a:1,
     8         b:2
     9     }
    10 };

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

    所以,你现在知道为什么vue组件的data必须是函数了吧。这都是因为js本身的特性带来的,跟vue本身设计无关。其实vue不应该把这个方法取名为data(),应该叫setData或其他更容易理解的方法名。

  • 相关阅读:
    关于C_Sharp集中处理异常
    关于Java连接SQL Sever数据库
    MongoDB 的主键 _id 为什么不是自增数字
    svn 命令行基本操作
    如何删除 Git 仓库中的历史提交记录
    .git 文件太大时怎样处理
    Git 提交到多个远程仓库
    Git SSH keygen 生成与配置
    Git 远端回滚
    Git 合并或修改线上 commit
  • 原文地址:https://www.cnblogs.com/doudou-song/p/14444689.html
Copyright © 2011-2022 走看看