reactive是用於復雜數據類型。
可以直接用引用進行賦值, 如果使用到了ref響應式就需要變量.value進行賦值。
torefs是因為把reactive的值轉成ref型,如果不轉就不能響應式。
<template> <!-- <img alt="Vue logo" src="./assets/logo.png"> --> <div> <h1>{{ name }}</h1> <h1>{{ age }}</h1> <button @click="sayName">按鈕</button> </div> </template> <script lang="ts"> import { computed, reactive,toRefs } from "vue"; interface DataProps { name: string; now: number; birthYear: number; age: number; sayName: () => void; } export default { name: "App", setup() { const data: DataProps = reactive({ name: "zhangsan", birthYear: 2000, now: 2020, sayName: () => { console.log(1111); console.log(data.name); data.name = "I am " + data.name; console.log(data.name); }, age: computed(() => { return data.now - data.birthYear; }), }); const refData = toRefs(data) refData.age return { ...refData, }; }, }; </script> <style> #app { font-family: Avenir, Helvetica, Arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; text-align: center; color: #2c3e50; margin-top: 60px; } </style>
詳情:https://blog.csdn.net/weixin_43342105/article/details/110233333