• 技术文章 >web前端 >前端问答

    vue里data为什么要用return返回数据

    青灯夜游青灯夜游2022-01-10 15:26:59原创74

    原因:不使用return包裹的数据会在项目的全局可见,会造成变量污染;而使用return包裹后数据中变量只在当前组件中生效,不会影响其他组件。

    本教程操作环境:windows7系统、vue2.9.6版,DELL G3电脑。

    官方:
    当一个组件被定义, data 必须声明为返回一个初始数据对象的函数,因为组件可能被用来创建多个实例。如果 data
    仍然是一个纯粹的对象,则所有的实例将共享引用同一个数据对象!通过提供 data 函数,每次创建一个新实例后,我们能够调用 data
    函数,从而返回初始数据的一个全新副本数据对象。

    为什么在项目中data需要使用return返回数据呢?

    类比与引用数据类型。如果不用function return 每个组件的data都是内存的同一个地址,那一个数据改变其他也改变了,这当然就不是我们想要的。用function return 其实就相当于申明了新的变量,相互独立,自然就不会有这样的问题;js在赋值object对象时,是直接一个相同的内存地址。所以为了每个组件的data独立,采用了这种方式。
    如果不是组件的话,正常data的写法可以直接写一个对象,比如同一组件中的两个计算器都共用了data:{ num : 0},JS中直接共享对象会造成引用传递,也就是说按了加减按钮后所有num值都会跟着修改,所以这里用function来每次返回一个对象实例。

    【相关推荐:vue.js教程

    以上就是vue里data为什么要用return返回数据的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:vue data return
    上一篇:vue-resource和vuex有什么区别 下一篇:vue有什么性能优化方法

    相关文章推荐

    • 在vue中按键修饰符有哪些• vue基于什么语言开发的• vue怎么控制元素的隐藏与显示• 带你深入了解vue2中的 v-model,看看如何让组件支持该语法• vue中v-bind和v-model的区别是什么• 推荐 20 个近期比较“火热”的Vue项目(值得收藏)

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网