• vue中组件的data为什么是一个函数


    组件是可复用的vue实例,一个组件被创建好之后,就可能被用在各个地方,而组件不管被复用了多少次,组件中的data数据都应该是相互隔离,互不影响的,基于这一理念,组件每复用一次,data数据就应该被复制一次,之后,当某一处复用的地方组件内data数据被改变时,其他复用地方组件的data数据不受影响。

    <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>

    该组件作为公共组件被三个不同的组件引用,但每个复用的地方组件内的count数据相互不受影响,它们各自维护各自内部的count:

    能有这样效果正是因为上述例子中的data不是一个单纯的对象,而是一个函数返回值的形式,所以每个组件实例可以维护一份被返回对象的独立拷贝

    组件中的data写成一个函数,数据以函数返回值形式定义,这样每复用一次组件,就会返回一份新的data,类似于给每个组件实例创建一个私有的数据空间,让各个组件实例维护各自的数据。而单纯的写成对象形式,就使得所有组件实例共用了一份data,就会造成一个变了全都会变的结果。

    原文:https://www.cnblogs.com/wangjiachen666/p/9876266.html

  • 相关阅读:
    nginx配置vue项目
    TexturePacker工具对素材打包
    java使用动态链接库
    java.lang.UnsatisfiedLinkError: no A in java.library.path
    pi4j与Spring Boot
    迪文屏串口修改数据
    迪文屏常用串口指令
    postcss-px-to-viewport移动端布局
    vue-lazyload延迟加载
    fastclick延迟300ms
  • 原文地址:https://www.cnblogs.com/xjy20170907/p/12745897.html
Copyright © 2020-2023  润新知