ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

toRef 和 toRefs

2022-01-30 18:00:56  阅读:166  来源: 互联网

标签:salary name age toRefs toRef person


toRef

<template>
  <div>姓名 {{name}}</div>
  <div>年龄 {{age}}</div>
  <div>工资 {{salary}}</div>
  <div>
    <button @click="name+='~'">修改姓名</button>
    <button @click="age++">增长年龄</button>
    <button @click="salary++">增加工资</button>
  </div>
</template>

<script>
import {reactive, toRef, } from "vue";
export default {
  name: 'Demo',
  setup() {
    let person = reactive({
      name: '张三',
      age: 18,
      job: {
        j1: {
          salary: 3000
        }
      }
    })
    return {
      name: toRef(person, 'name'),
      age: toRef(person, 'age'),
      salary: toRef(person.job.j1, 'salary')
    }
  }
}
</script>
  •  toRef 函数接收两个参数,响应式对象该对象上的某个属性
  •  toRef 函数返回一个响应式数据并且与原响应式对象中的该属性保持映射关系
  • 使用  toRef 的好处是可以将响应式对象中的某一个属性单独拿出来暴露给模板使用并且与原响应式对象中的那个属性有映射关系

toRefs

<template>
  <div>姓名 {{name}}</div>
  <div>年龄 {{age}}</div>
  <div>工资 {{job.j1.salary}}</div>
  <div>
    <button @click="name+='~'">修改姓名</button>
    <button @click="age++">增长年龄</button>
    <button @click="job.j1.salary++">增加工资</button>
  </div>
</template>

<script>
import {reactive, toRefs, } from "vue";
export default {
  name: 'Demo',
  setup() {
    let person = reactive({
      name: '张三',
      age: 18,
      job: {
        j1: {
          salary: 3000
        }
      }
    })
    return {
      ...toRefs(person)
    }
  }
}
</script>
  • 使用  toRefs 可以简化  toRef 的使用
  •  toRefs 函数接收一个响应式对象作为参数
  •  toRefs 函数返回一个对象,该对象中所有的属性与原响应式对象中的属性都保持映射关系
  • 通过ES6解构暴露  toRefs 函数返回的对象,从而简化模板中数据的使用

 

标签:salary,name,age,toRefs,toRef,person
来源: https://www.cnblogs.com/xiebenyin-/p/15857296.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有