zoukankan      html  css  js  c++  java
  • Vue实例初始化的选项配置对象详解

    Vue实例初始化的选项配置对象详解

    1. Vue实例的的data对象

    • 介绍

    Vue的实例的数据对象data 我们已经用了很多了,数据绑定离不开data里面的数据。也是Vue的核心属性。 它是Vue绑定数据到HTML标签的数据源泉,另外Vue框架会自动监视data里面的数据变化,自动更新数据到HTML标签上去。本质原理是:Vue会自动将data里面的数据进行递归抓换成getter和setter,然后就可以自动更新HTML标签了,当然用getter和setter所以老的浏览器Vue支持的不够好。

    • data对象的类型:

      • 类型是Object或者Function。
      • 如果是组件对象中,data必须是Function类型。【后面学了组件后就明白了,暂时对组件先放放。】
    • 实例:

    // 创建普通的Vue实例
    var vm = new Vue({
      data: data
    })
    // 组件定义 
    // Vue.extend() 中 data 必须是函数
    var Component = Vue.extend({ 
      data: function () { 
      //这里必须是函数!!!
        return { a: 1 }
      }
    })

    2. Vue实例的computed

    • 介绍

    Vue的计算属性(computed)的属性会自动混入Vue的实例中。所有 getter 和 setter 的 this 上下文自动地绑定为 Vue 实例。这就很强大了,再计算属性中定义的函数里面可以直接使用指向了vue实例的this,异常方便的啊。

    • 类型

    { 键:函数} { [key: string]: Function | { get: Function, set: Function } } 当然,可以省略setter,如果省略了setter,那么值就可以是普通函数,但是必须有返回值。

    • 官方的实例
      var vm = new Vue({
      data: { a: 1 },
      computed: {
        // 仅读取,值只须为函数
        aDouble: function () {
          return this.a * 2
        },
        // 读取和设置
        aPlus: {
          get: function () {
            return this.a + 1
          },
          set: function (v) {
            this.a = v - 1
          }
        }
      }
      })
      vm.aPlus   // -> 2
      vm.aPlus = 3
      vm.a       // -> 2
      vm.aDouble // -> 4
      

        

    3. methods

    • 类型: { [key: string]: Function }

    • 详细:

    methods 将被混入到 Vue 实例中。可以直接通过 VM 实例访问这些方法,或者在指令表达式中使用。方法中的 this 自动绑定为 Vue 实例。

    注意,不应该使用箭头函数来定义 method 函数 (例如 plus: () => this.a++)。理由是箭头函数绑定了父级作用域的上下文,所以 this 将不会按照期望指向 Vue 实例,this.a 将是 undefined。

    • 示例:
    var vm = new Vue({
      data: { a: 1 },
      methods: {
        plus: function () {
          this.a++
        }
      }
    })
    vm.plus()
    vm.a // 2

    4. watch

    • 类型

    { [key: string]: string | Function | Object }

    • 详细:

    一个对象,键是需要观察的表达式,值是对应回调函数。值也可以是方法名,或者包含选项的对象。Vue 实例将会在实例化时调用 $watch(),遍历 watch 对象的每一个属性。

    • 示例:
    var vm = new Vue({
      data: {
        a: 1,
        b: 2,
        c: 3
      },
      watch: {
        // 监控a变量变化的时候,自动执行此函数
        a: function (val, oldVal) {
          console.log('new: %s, old: %s', val, oldVal)
        },
        // 深度 watcher
        c: {
          handler: function (val, oldVal) { /* ... */ },
          deep: true
        }
      }
    })
    vm.a = 2 // -> new: 2, old: 1
    //注意,不应该使用箭头函数来定义 watcher 函数 (例如 searchQuery: newValue => this.updateAutocomplete(newValue))。理由是箭头函数绑定了父级作用域的上下文,所以 this 将不会按照期望指向 Vue 实例,this.updateAutocomplete 将是 undefined。 

    参考综合案例:

    <!DOCTYPE html> 
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <title>Vue入门之数据监控</title>
      <script src="https://unpkg.com/vue/dist/vue.js"></script>
    </head>
    <body>
      <div id="app">
        <p>{{ number }}</p>
        <input type="button" name="btnGetNumber" value="增加" v-on:click="getNumber()">
      </div>
      <script>
        var app = new Vue({         
          el: '#app',               
          data: {                   
            number: 1
          },
          methods: {
            // 事件响应方法的逻辑代码
            getNumber: function (e) {
              this.number += 1;   // 不管是内联方法调用,还是绑定事件处理器两种方式执行事件响应方法的时候 this都是指向 app
            }
          },
          watch: {
            // 监控number的变化,并自动执行下面的函数
            number: function (val, oldVal) {
              console.log('val:' + val + ' - oldVal: ' + oldVal);
            }
          }
        });
      </script>
    </body>
    </html>

    5. 设置el的详解

    • 类型

    string | HTMLElement

    限制: 只在由 new 创建的实例中遵守。

    • 详细:

    提供一个在页面上已存在的 DOM 元素作为 Vue 实例的挂载目标,也就是说Vue绑定数据到哪里去找。可以是CSS 选择器,也可以是一个 HTMLElement实例

    在实例挂载之后(生命周期的内容后面会详细讲的奥), 元素可以用 vm.$el 访问。

    如果这个选项在实例化时有作用,实例将立即进入编译过程,否则,需要显式调用 vm.$mount() 手动开启编译。

    // 几乎所有例子都用到这个,所以就不再赘述
    var app = new Vue({         
      el: '#app',
      ...
    });
    参考: http://www.cnblogs.com/fly_dragon/p/6220273.html
  • 相关阅读:
    idea存在包但是运行项目一直报java.lang.NoClassDefFoundError的问题
    记录一次服务器大中间表优化的问题(数据倾斜的解决)
    CDH spark2切换成anaconda3的问题
    关于(我们流量表优化),分区表数据块过多,聚合又导致数据倾斜问题
    大数据(流量表)任务问题清洗生成新分区表过程
    spark2.0在IDE运行的问题
    位运算应用
    SPSS数据的图表
    SPSS数据输入
    箭头函数中的this
  • 原文地址:https://www.cnblogs.com/crazycode2/p/6702058.html
Copyright © 2011-2022 走看看