首页 > 其他分享 >vue2与vue3中侦听器,Vue3中基础数据一个或多个ref

vue2与vue3中侦听器,Vue3中基础数据一个或多个ref

时间:2024-10-01 21:12:32浏览次数:1  
标签:count 侦听器 newVal oldVal vue2 vue3 ref

<template>
  <div id="app">
    <nav>
     <p>vue2与vue3侦听器的区别</p>
     <p>当前数值是: {{count}}</p>
     <button @click="count++">点击++</button>
     <hr>
     <p>当前字符串是: {{str}}</p>
     <button @click="str+='国庆节快乐'">点击改变字
    </nav>

  </div>
</template>
<script>
import { ref, watch } from 'vue'
export default {
  name: 'App',
  //这是vue2的侦听器
  #region vue2侦听器

  data() {
    return {
      count: 0
    }
  },
  watch: {
    这是简洁写的版本,vue2的侦听器
    count(newVal, oldVal) {
      console.log('newVal:', newVal, 'oldVal:', ol
    }   
    这是完整写法的侦听器
    count: {
      handler(newVal, oldVal) {
        console.log('newVal:', newVal, 'oldVal:', 
      },
      deep: true, // 深度侦听
      immediate: true // 立即执行
    }
  },
  #endregion

  //这是vue3的侦听器  ref定义的数据
  setup() {
    const count = ref(0)
    const str=ref('hello')

    //第一咱情况,侦听ref基础数据单一的数据
    // watch(count, (newVal, oldVal) => {
      // console.log('新值:', newVal, '旧值:', old
    // },{//这里可以写其他参数
      // deep: true, // 深度侦听,基础数据没有必要
      // immediate: true // 立即执行 
    // })

     //第二咱情况,对多个ref数据进行侦听
    watch([count,str], (newVal, oldVal) => {
      console.log('新值:', newVal, '旧值:', oldVal
    },{//这里可以写其他参数
      deep: true, // 深度侦听,基础数据没有必要深
      immediate: true // 立即执行 
    })
    return {count,str}
   }
 
  }
</script>
<style>
#app {
  font-family: Avenir, Helvetica, Arial, sans-seri
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  text-align: center;
  color: #2c3e50;
}

nav {
  padding: 30px;
}

nav a {
  font-weight: bold;
  color: #2c3e50;
}

nav a.router-link-exact-active {
  color: #42b983;
}
</style>


标签:count,侦听器,newVal,oldVal,vue2,vue3,ref
From: https://www.cnblogs.com/zy8899/p/18443335

相关文章

  • TypeScript在Vue中的使用-------ref
    我们平时的写法import{ref}from"vue";constmsg=ref("你好世界");使用TS的写法import{ref}from"vue";constmsg=ref<string>("你好世界");listType表示数组里面放对象,我们可以用如下的方法进行调用typelistType={id:numbername:......
  • vite5+tauri2.0+vue3+rust桌面exe聊天系统演示
    Tauri2.0-Vue3Chat:自研基于tauri2.0+rust+vue3setup+pinia2+element-plus等技术搭建的一款高颜值仿QQ/微信客户端聊天EXE软件。整个聊天窗口采用自定义无边框透明圆角阴影UI模式。tauri2.0-vitechat:自研vue3+tauri2+element-plus客户端聊天程序项目特点整体窗口采......
  • Vue3实现信息分类查询与信息搜索
    Vue实现分类与搜索tips:这是使用vue3组合式api实现的,需要将App.vue替换成下面的代码,之后运行就可以了<scriptsetup>import{ref,watchEffect,watch}from'vue';constmock=[{name:"小王",sex:0},{name:"小红",sex:1},{name:"小李",......
  • vscode 运行 C++分文件显示 undefined reference to 问题解决
    一、问题无法关联到对应的方法。  二、结局方法1、第一步,查看.vsode文件夹里面的task.json文件;设置里面参数;${file}改成 ${fileDirname}\\*.cpp 2、第二步 2.1、打开coderunner的setting.json文件; 2.2、将 $fileName改成*.cpp 3.3、最后起哄一下vs......
  • vue3+SpringBoot框架下的中小型生产企业订单管理系统
    目录功能和开发技术介绍具体实现截图开发核心技术介绍:技术创新点vue3和vue2的区别:核心代码部分展示非功能需求分析系统开发流程系统运行步骤软件测试源码获取功能和开发技术介绍本课题拟采用主流的MVC架构、开发工具idea、java语言编程、MySQL数据库技术、Vue.js技......
  • Vue3基于SpringBoot的高校学生实习综合服务平台设计与实现
    目录功能和开发技术介绍具体实现截图开发核心技术介绍:技术创新点vue3和vue2的区别:核心代码部分展示非功能需求分析系统开发流程系统运行步骤软件测试源码获取功能和开发技术介绍本课题拟采用主流的MVC架构、开发工具idea、java语言编程、MySQL数据库技术、Vue.js技......
  • [vue] vue3封装clip动画, 实现元素的国度效果
    import{nextTick}from"vue";//数据类型functiongetDataType(){returnObject.prototype.toString.call(arguments[0]).slice(8,-1).toLowerCase();}/****@param{*}els单元素节点或者元素节点集合*@param{*}fn数据变更的函数,通过调用函数导致......
  • Qt项目中,在main.cpp中定义了一个自定义组件,但是在编译的时候报错`undefined reference
    1、问题描述我在测试Qt项目的main.cpp中编写了如下代码:classMyWidget1:publicQWidget{Q_OBJECT};//main程序入口argc命令行变量的数量argv命令行变量的数组intmain(intargc,char*argv[]){//应用程序对象,在Qt中应用程序对象有且仅有一个QAppl......
  • [从零开始的 Vue3 系列]:Vue3 中常用组件通信全解析
    前言本系列将从零开始,系统性地介绍Vue3的常用API,逐步深入每个核心概念与功能模块。通过详尽的讲解与实战演示,帮助大家掌握Vue3的基础与进阶知识,最终具备独立搭建完整Vue3项目的能力。vue3中的组件通信Vue3提供了多种方式来进行组件之间的通信。根据场景的不......
  • vue3滚动条无法监测滚动高度问题
    第一个是根组件第二个是子组件第三个是滚动复用组件<el-scrollbarref="scroll"style="height:100%"@scroll="handleScroll">在滚动复用组件中想要监测滚动的高度变化,一开始没有使用el-scrollbar组件而是直接使用原生的格式导致如图所示滚动条与文......