zoukankan      html  css  js  c++  java
  • vue中data为什么是函数而不是对象

    vue组件是可复用的vue实例,一个组件被创建好之后,就可能被用在各个地方,而组件不管被复用了多少次,组件中的data数据都应该是相互隔离,互不影响的.

    基于这一理念,组件每复用一次,data数据就会被复制一次,之后,当某一处复用的地方组件内data数据被改变时,其他复用地方组件的data数据不受影响。

    1、函数

    <template>
        <div class="title">
            <h1>按钮被点击了{{ count }}次</h1>
            <button v-on:click="count++">点击</button>
        </div>
    </template>
    <script>
        export default {
          name: 'BtnCount',
          data () {
            return {
              count: 0
            }
          }
        }
    </script>
    <style scoped>
        .title {
            background-color: red
        }
    </style>

    结果:

    2、对象

    <template>
        <div class="title">
            <h1>按钮被点击了{{ count }}次</h1>
            <button v-on:click="count++">点击</button>
        </div>
    </template>
    <script>
        export default {
          name: 'BtnCount',
          data () {
            
              count: 0
            
          }
        }
    </script>
    <style scoped>
        .title {
            background-color: red
        }
    </style>

    结果:

     总结:如果data是对象的话,每当被复用是,复用的对象和源对象都会指向同一个内存地址(浅拷贝),互相之间相互影响,所以要是函数

  • 相关阅读:
    一个通用的事件监听函数全集
    单应性矩阵
    opencv姿态估计
    opencv相机标定
    Harris角点
    盒滤波Box Filter
    win10+vs2015+pcl1.8.1安装配置
    图像元素遍历
    阈值分割
    二叉树的层次遍历
  • 原文地址:https://www.cnblogs.com/xxflz/p/14116421.html
Copyright © 2011-2022 走看看