Vue2实例中的data属性三种写法与作用

Posted yangai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Vue2实例中的data属性三种写法与作用相关的知识,希望对你有一定的参考价值。

<script src="https://unpkg.com/vue/dist/vue.js"></script>
<div id="app">
    <span>{{count}}</span>
    <button @click="inc">+</button>
</div>
<script>
var app = new Vue({
  // 1.
  // data () {
  //   return {count: 0}
  // },
 
  // 2.
  // data: {
  //   count: 0
  // },
 
  // 3.
  data: function() {
    return {
      count: 0
    }
  },
 
  methods: {
    inc () {this.count++}
  }
})
app.$mount(‘#app‘)
</script>

首先,1是3的语法糖,是新的ES6语法,和3一摸一样。

然后1和2在官方文档上都有例子,区别也解释得很清楚。简而言之,在app = new Vue对象时,没什么区别,因为你app对象不会被复用。但是在组件中,因为可能在多处调用同一组件,所以为了不让多处的组件共享同一data对象,只能返回函数。function有作用域,所以别的组件访问不了。

 技术分享图片技术分享图片

 

以上是关于Vue2实例中的data属性三种写法与作用的主要内容,如果未能解决你的问题,请参考以下文章

vue2.0 props 数据传递

VueJS实例中data属性的三种写法及区别

vue实例中中data属性三种写法

Vue2.0学习—el与data的两种写法(三十六)

vue2.0--组件通信(非vuex法)

Vue 常用属性三种模板 总结