App.vue 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667
  1. <template>
  2. <h2>reactive的使用</h2>
  3. <h3>名字: {{user.name }}</h3>
  4. <h3>年龄:{{ user.age }}</h3>
  5. <h3>朋友: {{ user.firend }}</h3>
  6. <h3>性别: {{ user.sex }}</h3>
  7. <hr>
  8. <button @click="update">更新数据</button>
  9. </template>
  10. <script lang="ts">
  11. import { defineComponent,reactive } from 'vue'
  12. export default defineComponent({
  13. //定义多个数据的响应式
  14. //语法: const proxy = reactive(obj)
  15. //接收一个普通对象然后返回该普通对象的响应式代理器对象
  16. setup () {
  17. //需求: 显示用户相关信息,点击按钮,可以更新用户的相关信息
  18. //把数据变为响应式的
  19. const obj = ({
  20. name: '小明',
  21. age: 20,
  22. firend: {
  23. name: '小红',
  24. age: 18,
  25. cars: [1,2,3]
  26. }
  27. })
  28. //接收一个普通对象 然后返回该普通对象的响应式代理对象
  29. const user = reactive<any>(obj)
  30. //返回的是一个proxy代理对象 被代理这就是reactive传入的对象
  31. console.log(user)
  32. const update= ()=>{
  33. //user: 代理对象 obj: 目标对象
  34. // obj.name = '小兰'
  35. user.name = '小兰'
  36. user.age += 2
  37. user.firend.name += '+++'
  38. //user对象或者obj对象添加一个新的属性 哪种方式影响页面更新
  39. // obj.sex = '男'
  40. user.sex = '男'
  41. //这种方式可以使页面更新渲染,最终也会添加到目标对象里面
  42. //通过当前的代理对象找到该对象中的某个属性,更改属性中的某个数组的值
  43. user.firend.cars[1] = 'bmw'
  44. //通过当前的代理对象把目标对象中的某个数组属性添加一个新的属性
  45. user.firend.cars[3] = ''
  46. }
  47. return {
  48. // obj,
  49. user,
  50. update
  51. }
  52. }
  53. })
  54. </script>
  55. <style scoped>
  56. </style>