ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

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

2021-08-24 20:35:03  阅读:111  来源: 互联网

标签:vue 函数 951 demo Component 实例 new data


  我们先看看 官方给出得data的说明:

  

 

 

   

  让我们来看一个例子:

  

new  Vue({
    el: '#app',
    template: `<div>{{name}}</div>`,
    data: {
        demo: '951'
    }
})

  在new vue()中,data可以直接是一个对象,为什么在vue组件中,data必须是一个函数呢?

   让我们再看下面这个原型链:

  

var Component = function() {};
Component.prototype.data = {
    name: '951'
}
var component1 = new Component();
var component2 = new Component();
component1.data.demo = '951';
console.log(component2.data.demo); // 951

  一个组件被复用多次的话,也就会创建多个实例。本质上,这些实例用的都是同一个构造函数。如果data是对象的话,对象属于引用类型,会影响到所有的实例。所以为了保证组件不同的实例之间data不冲突,data必须是一个函数。
  而 new Vue 的实例,是不会被复用的,因此不存在引用对象的问题。

标签:vue,函数,951,demo,Component,实例,new,data
来源: https://www.cnblogs.com/sy2077/p/15181983.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有