首页 > 其他 > 详细

vue基础之计算属性和侦听器

时间:2020-01-16 20:37:01      阅读:85      评论:0      收藏:0      [点我收藏+]

categories:

  • vue基础
    tags:
  • 计算属性
  • 侦听器

计算属性

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>计算属性和侦听器</title>
    <style>

    </style>
</head>
<body>
    <div id="app">
        <div>计算属性</div>
        <!-- 计算属性-->
        <p>我们可以将同一函数定义为一个方法而不是一个计算属性。两种方式的最终结果确实是完全相同的。然而,不同的计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。这就意味着只要msg还没有改变,多次访问reversedMessage计算属性会立即返回之前的计算结果,而不必再次执行函数</p>
        <p >{{ msg }}</p>
        <p>{{ reversedMessage }}</p>
        <hr>

        <div>侦听器</div>
        <!-- 侦听器-->
        <p>
        Ask a yes/no question:
        <input v-model="question">
        </p>
        <p>{{ answer }}</p>
        <hr>
    </div>
    
    <!-- 1. 引包-->
    <!-- 因为 AJAX 库和通用工具的生态已经相当丰富,Vue 核心代码没有重复 -->
    <!-- 提供这些功能以保持精简。这也可以让你自由选择自己更熟悉的工具。 -->
    <script src="https://cdn.jsdelivr.net/npm/axios@0.12.0/dist/axios.min.js"></script>
    <script src="https://cdn.jsdelivr.net/npm/lodash@4.13.1/lodash.min.js"></script>
    <script src="./vue.js"></script>
    <script>
        // 2.初始化
        const vm = new Vue({
            el: '#app',
            // 数据属性
            data: {
                msg:'',
                question: '',
                answer: 'I cannot give you an answer until you ask a question!'
            },
            methods:{
                getAnswer: function () {
                  if (this.question.indexOf('?') === -1) {
                    this.answer = 'Questions usually contain a question mark. ;-)'
                    return
                  }
                  this.answer = 'Thinking...'
                  var vm = this
                  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
                    })
                }
            
            },
            computed: {
                reversedMessage: function () {
                    return this.msg.split('').reverse().join('')
                }
            },
            watch: {
                // 如果 `question` 发生改变,这个函数就会运行
                question: function (newQuestion, oldQuestion) {
                  this.answer = 'Waiting for you to stop typing...'
                  this.debouncedGetAnswer()
                }
            },
            created: function () {
                // `_.debounce` 是一个通过 Lodash 限制操作频率的函数。
                // 在这个例子中,我们希望限制访问 yesno.wtf/api 的频率
                // AJAX 请求直到用户输入完毕才会发出。想要了解更多关于
                // `_.debounce` 函数 (及其近亲 `_.throttle`) 的知识,
                // 请参考:https://lodash.com/docs#debounce
                this.debouncedGetAnswer = _.debounce(this.getAnswer, 500)
            }


        })

    </script>
</body>
</html>

vue基础之计算属性和侦听器

原文:https://www.cnblogs.com/anyux/p/12203002.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!