VUE 入门基础(4)

四,计算属性

  基础例子

    <div id=‘example’>
      <p>0riginal message: “{{message}}”</p>
      <p>Computed reversed message:”{{reversedMessage}}”</p>
    </div>
    Var vm = new Vue({
      el: “#example”,
      data: {
        message: ‘Hello’
      },
      computed: {
        reversedMessage: function() {
        return this.message.split(“ ”).reverse().join(‘ ’)
      }
    }
  })

  声明了一个计算属性 reversedMessage 。我们提供的函数将用作属性 vm.reversedMessage 的 getter

    console.log(vm.reversedMessage)   // olleH
    vm.message = ‘Goodbye’
    console.log(vm.reversedMessage) // eybdooG

  计算缓存

  注意到我们可以通过调用表达式中的method来达到同样的效果:

    <p>Reversed message: "{{ reverseMessage() }}"</p>
    methods: {
      reverseMessage: function (){
      return this.message.split(‘ ’).reverse().join(‘ ’)
      }
    }

  计算属性是基于它的依赖缓存。计算属性只有在它的相关依赖发生改变时才会重新取值。这就意味着只要message 没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

  计算属性 watched Property

  Vue提供了一个方法 $watch, 它用于观察vue 实例上的数据变动。

  <div id=‘demo’>{fullName{}}</div>
    Var vm = new Vue({
      el:‘#demo’,
      data: {
        firstName: ‘Foo’,
        lastName:‘Bar’,
        fullName:‘Foo Bar’
      } ,
    Watch: {
      firstName:  function (val){
      this.fullName = val + ‘ ’+ this.lastName
    },
    lastName: function (val){
      this.fullName = this.firstName + ‘ ’+val
      }
    }
  })

  计算 setter

  计算属性默认只有getter, 不过在需要时你也可以提供一个setter:

    computed: {
      fullName: {
        get: function () {
        Return this.firstName +””+this.lastName
      },
      set: function (newValue) {
        Var names = newValue.split(‘ ’)
        this.firstName = name[0]
        this.lastName = name[names.length - 1]
      }
    }
  }

  现在在运行 vm.fullName = 'John Doe' 时, setter 会被调用, vm.firstName 和 vm.lastName 也会被对应更新。

  观察watchers

  Vue 提供一个更通用的方法通过watch 选项,来响应数据的变化,当你想要在数据变化响应时,执行异步操作或开销较大的操作。

  <div id="watch-example">
      <p>
          Ask a yes/no question:
          <input v-model="question">
      </p>
      <p>{{ answer }}</p>
  </div>
  <script>
    var watchExampleVM = new Vue({
        el: '#watch-example',
        data: {
            question: '',
            answer: 'I cannot give you an answer until you ask a question!'
        },
        watch: {
    // 如果 question 发生改变,这个函数就会运行
    question: function (newQuestion) {
        this.answer = 'Waiting for you to stop typing...'
        this.getAnswer()
      }
    },
    methods: {
      // _.debounce 是一个通过 lodash 限制操作频率的函数。
      // 在这个例子中,我们希望限制访问yesno.wtf/api的频率
      // ajax请求直到用户输入完毕才会发出
      // 学习更多关于 _.debounce function (and its cousin
      // _.throttle), 参考: https://lodash.com/docs#debounce
      getAnswer: _.debounce(
          function () {
            var vm = this
            if (this.question.indexOf('?') === -1) {
              vm.answer = 'Questions usually contain a question mark. ;-)'
              return
          }
        vm.answer = 'Thinking...'
        axios.get('https://yesno.wtf/api')
          .then(function (response) {
                vm.answer = _.capitalize(response.data.answer)
           })
          .catch(function (error) {
                vm.answer = 'Error! Could not reach the API. ' + error
              })
        },
        // 这是我们为用户停止输入等待的毫秒数
        500
      )
    }
})
</script>

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏禅林阆苑

mysql学习总结02 — 数据类型

无符号:表示存储的数据在当前字段中,没有负数(只有正数,例如 tinyint 区间为 0~255)

20620
来自专栏HTML5学堂

轻松但深入的学习闭包原理 —— 曾让几乎所有JS新手痛恨的知识

HTML5学堂-码匠:这或许是你看过的,最浅显易懂的一篇关于闭包原理的讲解! 闭包的官方定义 官方定义:闭包是一个拥有许多变量和绑定了这些变量的环境的表达式(通...

39760
来自专栏Web行业观察

DOM中历史遗留的那些天坑 ...

即时到了DOM3.0时代, 为了同时满足浏览器的向下兼容和ES6的最新街口, DOM还是保留了很多古老的,极易和新类型引起混淆的类比如HTMLCollectio...

15760
来自专栏desperate633

设计模式之原型模式(Prototype 模式)引入原型模式原型模式的实例小结为什么需要使用原型模式

联想到浏览器中,如果我们生成了一个button实例,这个button实例经过一系列操作,携带了各种信息,比如button加颜色,加背景图,加文字,加事件等等。如...

7820
来自专栏Linux驱动

汇编指令-CMP、TEQ(5)

 cmp:(compare)指令进行比较两个操作数的大小  格式: cmp oprd1,oprd2 比较oprd1和oprd2操作数,然后通过助记符来实现想要的...

207100
来自专栏Golang语言社区

Golang 基本语法学习笔记之流程控制

条件判断 //实例 func fn01(x int) int { var a int if a = 4; x == 0 {...

276120
来自专栏贾鹏辉的技术专栏@CrazyCodeBoy

ES6、ES7、ES8学习指南

ES全称ECMAScript,ECMAScript是ECMA制定的标准化脚本语言。目前JavaScript使用的ECMAScript版本为ECMAScript-...

21240
来自专栏高爽的专栏

Flex回调函数

        首先要说明一下什么是回调函数?有什么作用?         回调函数就是一个通过函数指针调用的函数。如果你把函数的指针(地址)作为参数传递给另一...

21300
来自专栏开心的学习之路

JavaScript概览

近日的项目需要用JavaScript完成,于是决定通读《JavaScript高级程序设计第三版》,书是2012年的,比较老了,但是可以用来快速了解JavaScr...

30340
来自专栏Golang语言社区

Golang语言中的流程控制结构和函数详解

流程控制 流程控制在编程语言中是最伟大的发明了,因为有了它,你可以通过很简单的流程描述来表达很复杂的逻辑。Go中流程控制分三大类:条件判断,循环控制和无条件跳转...

38870

扫码关注云+社区

领取腾讯云代金券