zoukankan      html  css  js  c++  java
  • vuejs中的计算属性和监视

    计算属性

    1.在computed属性对象中定义计算属性的方法,在页面上使用{{方法名}}来显示计算结果

    2.通过getter/setter实现对属性数据的显示和监视

    3.计算属性存在缓存,多次读取只执行一次getter

    侦听属性

    1.通过vm对象的$watch()或watch配置来监视指定的属性

    2.当属性变化时,回调函数自动调用,在函数内部进行计算

    计算属性与方法、侦听属性之间的比较

    计算属性是基于它们依赖进行缓存,只有相关依赖发生改变时才会重新求值,调用方法是每当重发重新渲染时,总会调用执行函数。而侦听属性可以实现相应数据变动,但是它对需要侦听的属性编写重复的代码。但是watch在异步操作数据变化时很合适。

    举个例子:

    <!DOCTYPE html>
    <html lang="en">
    <head>
      <meta charset="UTF-8">
      <script src="https://cdn.jsdelivr.net/npm/vue@2.5.17/dist/vue.js"></script>
    </head>
    <body>
    <div id="demo">
      姓: <input type="text" placeholder="First Name" v-model="firstName"><br>
      名: <input type="text" placeholder="Last Name" v-model="lastName"><br>
      <!--fullName1是根据fistName和lastName计算产生-->
      姓名1(单向): <input type="text" placeholder="Full Name1" v-model="fullName1"><br>
      姓名2(单向): <input type="text" placeholder="Full Name2" v-model="fullName2"><br>
      姓名3(双向): <input type="text" placeholder="Full Name3" v-model="fullName3"><br>
    
      <p>{{fullName1}}</p>
      <p>{{getFullName()}}</p>
    </div>
    
    <!--<script type="text/javascript" src="../js/vue.js"></script>-->
    <script type="text/javascript">
      const vm = new Vue({
          el: '#demo',
          data: {
              firstName: 'A',
              lastName: 'B',
              fullName2: 'A-B'
          },
          methods: {
              getFullName: function () {
                  return this.firstName + '-' + this.lastName
              }
          },
    
          // 计算属性配置: 值为对象
          computed: {
              fullName1() { // 属性的get()
                  // console.log('fullName1()', this)
                  return this.firstName + '-' + this.lastName
              },
    
              fullName3: {
                  // 当获取当前属性值时自动调用, 将返回值(根据相关的其它属性数据)作为属性值
                  get() {
                      console.log('fullName3 get()')
                      return this.firstName + '-' + this.lastName
                  },
                  // 当属性值发生了改变时自动调用, 监视当前属性值变化, 同步更新相关的其它属性值
                  set(value) {// fullName3的最新value值  A-B23
                      console.log('fullName3 set()', value)
                      // 更新firstName和lastName
                      const names = value.split('-')
                      this.firstName = names[0]
                      this.lastName = names[1]
                  },
              },
          },
    
                  watch: {
                      // 配置监视firstName
                      firstName: function (value) { // 相当于属性的set
                          console.log('watch firstName', value)
                          // 更新fullName2
                          this.fullName2 = value + '-' + this.lastName
                      },
                      lastName: function (value) {
                          this.fullName2 = this.firstName + '-' + value;
                      }
                  }
    
      })
    
    </script>
    </body>
    </html>

    运行结果中fullName1和fullName2数据传输是“单向”的(输入firstname和lastname时fullname会相应变化,但是反过来就不行),fullName3实现数据传输双向的,当输入fullname时,firstname和lastname会相应的改变。get为取值,set为赋值

  • 相关阅读:
    遗传算法-目标函数与适应度函数变换
    遗传算法-编码
    Python 绘制甘特图
    fiddler抓包
    使用msf查询补丁和可利用提权漏洞
    Shodan入坑指南
    python 项目自动生成requirements.txt文件
    Tomcat 基于端口的虚拟主机配置
    python简单搭建http server
    metasploit后渗透 之 portfwd端口重定向
  • 原文地址:https://www.cnblogs.com/lanhuo666/p/10451753.html
Copyright © 2011-2022 走看看