IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> JavaScript知识库 -> [Vue3学习笔记]computed+watch+watchEffect -> 正文阅读

[JavaScript知识库][Vue3学习笔记]computed+watch+watchEffect

计算属性与监视

computed函数

- 如果传入一个回调,表示是get
    const fullName1= computed(()=>{
      return user.firstName+'_'+user.lastName
    })
- 如果要有get和set,那需要传入一个对象
    const fullName2= computed({
      get(){
          return user.firstName+'_'+user.lastName
      },
      set(val:string){
        const names=val.split('_')
        user.firstName=names[0]
        user.lastName=names[1]
      }
    })

watch函数

和vue2的区别可以:监听自身属性了?
可以深度监听是真的方便

    // 监视指定的数据
    const fullName3=ref('')
    watch(user,({firstName,lastName})=>{
        fullName3.value=firstName+'_'+lastName
    },{immediate:true,deep:true})

watch可以监听多个数据,如果监听非响应式数据要加()=>

    watch([()=>user.firstName,()=>user.lastName],()=>{
      console.log('++++');
    })

watchEffect函数

    // 不需要配置immediate,本身默认会进行监视
    watchEffect(()=>{
      fullName3.value=user.firstName+'_'+user.lastName
    })

通过watchEffect实现监听改变firstName和lastName

    watchEffect(()=>{
      const names=fullName3.value.split('_')
      user.firstName=names[0]
      user.lastName=names[1]
    })

完整代码

<!--
 * @Author: 41
 * @Date: 2021-12-07 17:12:43
 * @LastEditors: 41
 * @LastEditTime: 2021-12-14 16:31:25
 * @Description: 
-->
<template>
  <h2>计算属性和监视</h2>
  <fieldset>
    <legend>姓名操作</legend>
    姓氏:<input type="text" placeholder="请输入姓氏" v-model="user.firstName"/><br/>
    名字:<input type="text" placeholder="请输入名字" v-model="user.lastName"/>
  </fieldset>
  <fieldset>
    <legend>计算属性和监视的演示</legend>
    姓名<input type="text" placeholder="显示姓名" v-model="fullName1"/><br/>
    姓名<input type="text" placeholder="显示姓名" v-model="fullName2"/><br/>
    姓名<input type="text" placeholder="显示姓名" v-model="fullName3"/><br/>
  </fieldset>
</template>

<script lang="ts">
import {computed, defineComponent, reactive,watch,ref, watchEffect} from 'vue'
export default defineComponent({
  name:'App',
  setup(){
    const user=reactive({
      firstName:'1',
      lastName:'2'
    })
    // 通过计算属性的方式,实现第一个姓名的显示
    // vue3中的计算属性
    // 计算属性的函数中如果只传入一个回调函数,表示get
    // 第一个姓名返回的时一个Ref类型对象
    const fullName1= computed(()=>{
      return user.firstName+'_'+user.lastName
    })
    // 第二个姓名:
    const fullName2= computed({
      get(){
          return user.firstName+'_'+user.lastName
      },
      set(val:string){
        const names=val.split('_')
        user.firstName=names[0]
        user.lastName=names[1]
      }
    })
    // 监视指定的数据
    const fullName3=ref('')
    watch(user,({firstName,lastName})=>{
        fullName3.value=firstName+'_'+lastName
    },{immediate:true,deep:true})
    // immediate默认自动执行一次 deep深度监视

    // 不需要配置immediate,本身默认会进行监视
    watchEffect(()=>{
      const names=fullName3.value.split('_')
      user.firstName=names[0]
      user.lastName=names[1]
    })
    watch([()=>user.firstName,()=>user.lastName],()=>{
      console.log('++++');
    })
    return{
      user,
      fullName1,
      fullName2,
      fullName3
    }
  }
})
</script>
  JavaScript知识库 最新文章
ES6的相关知识点
react 函数式组件 & react其他一些总结
Vue基础超详细
前端JS也可以连点成线(Vue中运用 AntVG6)
Vue事件处理的基本使用
Vue后台项目的记录 (一)
前后端分离vue跨域,devServer配置proxy代理
TypeScript
初识vuex
vue项目安装包指令收集
上一篇文章      下一篇文章      查看所有文章
加:2021-12-15 18:10:55  更:2021-12-15 18:11:21 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2025年1日历 -2025/1/8 2:04:43-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码