|
|
@@ -0,0 +1,31 @@
|
|
|
+<template>
|
|
|
+ <div>
|
|
|
+ <h1>Demo20</h1>
|
|
|
+ <p>姓: <input type="text" v-model="user.firstName"></p>
|
|
|
+ <p>名: <input type="text" v-model="user.lastName"></p>
|
|
|
+ <p>全名:{{ fullName }}</p>
|
|
|
+ </div>
|
|
|
+</template>
|
|
|
+
|
|
|
+<script lang="ts" setup>
|
|
|
+import {ref, watch, watchEffect} from "vue"
|
|
|
+let user = ref({
|
|
|
+ firstName:"胡",
|
|
|
+ lastName:"图图"
|
|
|
+})
|
|
|
+let fullName = ref("");
|
|
|
+// watch(user,({firstName,lastName}) => {
|
|
|
+// // console.log(val,'val')
|
|
|
+// fullName.value = firstName + lastName;
|
|
|
+// },{
|
|
|
+// deep: true,
|
|
|
+// immediate: true
|
|
|
+// })
|
|
|
+// 立即执行函数 响应式追踪依赖 在依赖发生变化时候 触发执行回调
|
|
|
+watchEffect(()=>{
|
|
|
+ fullName.value = user.value.firstName + user.value.lastName;
|
|
|
+})
|
|
|
+</script>
|
|
|
+
|
|
|
+<style lang="scss" scoped>
|
|
|
+</style>
|