iis服务器助手广告广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue中watch的实际开发学习笔记
  • 866
分享到

vue中watch的实际开发学习笔记

vue中watch的作用vue的watch函数vue watch 方法 2022-11-13 19:11:23 866人浏览 独家记忆
摘要

目录前言一、watch是什么二、watch不同的实际使用场景开发案例1.场景1:加载完成后登录监听2.场景2:前面不同的选择框,影响下面的不同的选择框的选项内容3.场景3:深度监听4

前言

本文主要是积累一下在使用前端的watch开发过程中遇到的问题点和经验。

一、watch是什么

根据本人的理解,它就是一个监听器,就是说监听的某个数据发生了变化,那么它就会执行相对应的函数。它主要使用在哪些场景呢,比如:一个数据影响着多个数据的业务。

  watch:{  // 当这个workType发生改变时,就是1个数据的改变,就会影响到type5和foll的改变
    'queryParams.workType':function (newName,oldName){
      if(newName==1){
        this.type5 = this.type3,
        this.foll = true
      }else if(newName==2){
        this.type5 = this.type4,
        this.foll = false
      }
    }
  },

二、watch不同的实际使用场景开发案例

1.场景1:加载完成后登录监听

代码如下:

  watch: {
    isLoading (newVal, oldVal) { //1. 原来的值,和现在的值,是否有变化,如果有变化,触发这个函数
      console.log('2 isLoading newVal is ', newVal, ' , oldVal is ', oldVal)
 
      //2. 当加载完成时, 还需要判断用户是否已登录
      const username = getLoginedUsername(this.$store)
      if (username != undefined && username != null) {
        // 已登录时, 跳转首页
        toHomePage(this)
      }
    }
  },
 
  computed: {
    isLoading () {
      return isLoading(this.$store)
    }
  },
 
import { isLoading, getLoginedUsername } from 'utils/utils'

2.场景2:前面不同的选择框,影响下面的不同的选择框的选项内容

1.data的代码如下:

 data() {
    return {
      verifyData: this.propData,
      editBoxShow: false,
 
      type3: [{
        worksRegion: '0',
        label: '牛奶'
      },{
        worksRegion:"1",
        label: "面包"
      },
        {
          worksRegion:"3",
          label: "水果"
        }
      ],
      type4: [{
        worksRegion: '0',
        label: '炸鸡'
      },{
        worksRegion:"1",
        label: "汉堡"
      },{
          worksRegion:"2",
          label: "可乐"
        },
        {
          worksRegion:"3",
          label: "北京烤鸭"
        }
      ],
      type5:[],
     
      queryParams:{
        id:"",
        workType:'',//1开发 , 2 测试 
        foll:true
      },
 
    };
}

2.watch的监听

  watch:{  // 当这个workType发生改变时,就是1个数据的改变,就会影响到type5和foll的改变
    'queryParams.workType':function (newName,oldName){
      if(newName==1){
        this.type5 = this.type3,
        this.foll = true
      }else if(newName==2){
        this.type5 = this.type4,
        this.foll = false
      }
    }
  },

3.场景效果描述

比如:      第1个选框:开发;

                第2个选框: A,B,C

比如:      第1个选框:测试;

                第2个选框: A,B,C,D

  由上所示,当第1个选框,选择“开发”选项时,则第2个选框出现的选项内容为ABC;当第1个选框,选择“测试”选项时,则第2个选框出现的选项内容为ABCD;这时就实现了当初的上一个不同选项出现下一个不同的选项内容的效果了。

原理描述:它是主要是通过判断queryParams的里面的workType的参数的变化,来进行监听的,如果当用户点了开发这个选项,那么这个workType的newName就是1了,所以就触发了watch里面的这个函数了,那么这里就可以进行业务方面的处理即可。

3.场景3:深度监听

说明:
 
handler: 固定方法触发
deep: 开启深度监听
immediate: 页面初始化时handler立即执行一次
 
  data(){
    return {
      user: {
        userNo: "",
        sex: ""
      }
    }
  },
 
  // 监听整对象
  watch: {
        // 监听整个对象,对象里的每个属性值的变化都会执行handler,执行后获取的 newVal 值和 oldVal 值是一样的
    user: {
      handler(newVal, oldVal){
        console.log(newVal, oldVal);
      },
      deep: true,
      immediate: true
    }
  }
 
 watch: {
       // 监听对象的某个属性,被监听的属性值发生变化就会执行函数,但获取的 newVal 值和 oldVal 值不一样
    'user.userNo': {
      handler(newVal, oldVal){
        console.log(newVal, oldVal);
      },
      deep: true,
      immediate: true
    }
  }
 
 

4.场景4:赋值使用

  watch: {
    traysNos (newVal, oldVal) {
      if ((newVal && !oldVal) || (newVal && oldVal && newVal !== oldVal)) {
        this.filterDeliverysOutLists = []
        this.deliverysOutsList = this.fullsDeliverysOutsLists
      }
    }
  },

5.场景5:改变标记的true和false

   data () {
    return {
      loading: false,
      submitsCheck: true,
    }
  },
 
 watch: {
    'order.traysNos' (val) {
      if (val == null || val == '') {
        this.submitsCheck = true
      } else if (val) {
        this.submitsCheck = false
      }
    }
  },
 

6.场景6:页面的跳转

  watch: {
    reservesNo (newVal, oldVal) {
      if ((newVal && !oldVal) || (newVal && oldVal && newVal !== oldVal)) {
        this.reservesNo = newVal // 获取到新值
        this.$router.replace({  // 跳转,注意,这种跳转,是不可以回退的
          query: {
            reservesNo: this.reservesNo  // 传新值
          }
        })
        this.findOrderNo()  // 执行其他的函数
      }
    }
  },

这个主要是深度监听的使用,如何监听某个对象中的某个属性的变化,就是上面这个案例,看业务需求来进行使用。

补充:watch简写形式

如果只是监听单个简单的数据,使用watch的简写形式就可以满足需求。

代码如下:

<script>
export default {
  name: "Home",
  data() {
    return {
      text: ""
    };
  },
  watch: {
    text(newVal, oldVal) {
      
    }
  },
};
</script>

总结

本文主要是积累一下在使用前端的watch开发过程中遇到的问题点和经验。

到此这篇关于Vue中watch的实际开发笔记的文章就介绍到这了,更多相关vue中watch开发内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue中watch的实际开发学习笔记

本文链接: http://www.lsjlt.com/news/171013.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • vue中watch的实际开发学习笔记
    目录前言一、watch是什么二、watch不同的实际使用场景开发案例1.场景1:加载完成后登录监听2.场景2:前面不同的选择框,影响下面的不同的选择框的选项内容3.场景3:深度监听4...
    99+
    2022-11-13
    vue中watch的作用 vue的watch函数 vue watch 方法
  • 《Flask Web开发》学习笔记
      前言:想熟练掌握一门web框架,为以后即将诞生的测试工具集做准备。为什么选择flask要做熟练掌握的一门框架,而不是其他的,最主要的原因是可以随意定制。   特别提醒:这本书的代码会提交在github,有基础的人可以直接看githu...
    99+
    2023-01-30
    学习笔记 Flask Web
  • Web 开发学习笔记(1) --- 搭
    简介 Flask 是一个轻量级的 Web 框架, 如果要学习 Web 开发, Flask 非常适合作为我们学习的起点. 通过接下来的这一些列的博客, 我们将学习如何利用 Flask 以及其他工具, 搭建一个简单的网站. We'll bu...
    99+
    2023-01-31
    学习笔记 Web
  • Web 开发学习笔记(3) --- 申
    简介 现在已经进入 HTTPS 的时代, HTTPS 证书 目前应用广泛, 发展迅速. 相较于明文传输的 HTTP, HTTPS 更加安全. HTTPS 即 Hypertext Transfer Protocol Secure, ...
    99+
    2023-01-31
    学习笔记 Web
  • 学习 PHP:如何在笔记中记录开发技术?
    PHP是一种流行的服务器端编程语言,它被广泛用于开发Web应用程序。对于那些刚开始学习PHP的人来说,如何记录和整理学习笔记是一个非常重要的问题。在本文中,我们将介绍一些关于如何在笔记中记录PHP开发技术的技巧和建议。 使用Markdo...
    99+
    2023-09-02
    学习笔记 开发技术 存储
  • PHP学习笔记:设计模式与开发实践
    在现代软件开发中,设计模式是一个非常重要的概念。设计模式是软件开发中常见问题的解决方案,它们被广泛用于解决不同领域的各种问题。在PHP开发中,掌握设计模式可以帮助我们编写可维护、可扩展、可重用的代码。本文将介绍几种常见的设计模式,并展示如何...
    99+
    2023-10-21
    PHP 设计模式 开发实践
  • GO语言实时开发技术,开发者必备学习笔记
    随着人工智能和物联网技术的发展,实时应用的需求越来越多。GO语言是一种现代化的高性能编程语言,它的运行速度快、并发性能好、内存占用小、语法简单易懂,这些特性使得GO语言成为实时应用开发的优秀选择。本文将介绍一些GO语言实时开发的技术和工具...
    99+
    2023-11-12
    实时 开发技术 学习笔记
  • PHP数组存储:从学习笔记到实际应用。
    PHP是一种非常流行的服务器端编程语言,它的应用范围非常广泛。在PHP中,数组是一种非常重要的数据类型,它可以用来存储多个值,并且可以根据需要进行动态调整。本文将从学习笔记到实际应用,介绍PHP数组的存储方式和实际应用。 一、学习笔记 数...
    99+
    2023-08-05
    存储 学习笔记 数组
  • GO语言实时开发技术,学习笔记指南
    GO语言是一种开源的编程语言,由Google开发,其语法简单、并发性能优异、可靠性高,因此在实时开发领域应用广泛。对于想要学习GO语言实时开发技术的初学者,本篇文章将提供一些学习笔记指南。 一、基础语法 GO语言的基础语法与其他语言相似,...
    99+
    2023-11-12
    实时 开发技术 学习笔记
  • Python3学习笔记:Python中的
    一、格式 变量 = 对象 二、简述 Python为动态解释性语言,在赋值操作时,并不需要像静态编译类型语言C、C++或Java一样,在使用变量前,需声明变量的类型。在Python中,类型是在运行过程中自动决定的,而不是通过代码声...
    99+
    2023-01-31
    学习笔记 Python
  • Java学习笔记:掌握Linux下的开发环境
    Java是一种面向对象的编程语言,具有跨平台性和安全性,因此在软件开发领域广泛应用。而Linux作为一种开源的操作系统,也得到了广泛的应用。本文将介绍如何在Linux下搭建Java开发环境,并演示一些常用的代码。 一、安装Java环境 首...
    99+
    2023-06-02
    linux ide 学习笔记
  • GO语言开发技术:学习笔记分享!
    GO语言是一门高效、可靠、可扩展的编程语言,由Google开发。它的出现解决了许多其他编程语言的问题,例如C++中的指针问题、Java中的垃圾回收等等。 GO语言在现代化的软件开发中,已经被广泛应用,并成为了云计算领域的事实标准。本篇文章...
    99+
    2023-08-02
    学习笔记 开发技术 linux
  • 从零开始学习PHP和Spring:API开发必备笔记
    随着互联网的发展,Web应用程序的需求也越来越高,而API开发已成为Web应用程序的重要组成部分。而对于API开发人员来说,掌握PHP和Spring框架的知识显得尤为重要。在本文中,我们将从零开始学习PHP和Spring框架的基础知识,以...
    99+
    2023-09-10
    学习笔记 spring api
  • 如何记录自己的LeetCode学习笔记?ASP开发者的实践分享
    LeetCode是一家知名的在线编程题库,它的题目难度逐渐递增,可以很好地锻炼我们的算法思维和编程能力。但是,在做题的过程中,我们需要记录自己的思路和解题过程,这样才能更好地回顾和总结。本文将介绍如何记录自己的LeetCode学习笔记,并分...
    99+
    2023-06-23
    leetcode 学习笔记 日志
  • Java接口学习笔记:如何在实时中学习?
    Java是一种广泛使用的编程语言,它的重要特性之一就是接口。接口是一种约束,它规定了类应该具有哪些行为。学习接口是Java编程的基础,本文将介绍Java接口的基本概念和如何在实时中学习。 一、Java接口的基本概念 接口是一种特殊的类,它...
    99+
    2023-09-25
    接口 学习笔记 实时
  • PHP学习笔记:游戏开发与物理引擎
    摘要:随着互联网的发展,游戏开发变得越来越流行。PHP作为一种流行的服务器端编程语言,也可以用于游戏开发。本文将介绍如何使用PHP进行游戏开发,并结合物理引擎实现更加逼真的游戏效果。文章将着重介绍游戏物理引擎的概念和使用方式,并提供详细的代...
    99+
    2023-10-21
    PHP 游戏开发 物理引擎
  • PHP学习笔记:移动应用与原生开发
    移动应用的普及和原生开发的需求逐渐增加,对于PHP开发者来说,掌握移动应用与原生开发技术是一项重要的能力。本篇文章将介绍PHP开发者如何利用PHP进行移动应用开发,并提供一些具体的代码示例。一、移动应用开发概述移动应用是指在移动设备上运行的...
    99+
    2023-10-21
    PHP 移动应用 原生开发
  • PHP学习笔记:论坛与博客系统开发
    在Web开发领域中,论坛和博客系统是非常常见的应用程序。它们为用户提供了一个交流和分享信息的平台。在本篇文章中,我们将讨论如何使用PHP开发一个简单的论坛和博客系统,并附上具体的代码示例。环境设置首先,我们需要搭建一个适合PHP开发的开发环...
    99+
    2023-10-21
    开发 PHP 学习笔记
  • GO语言实时开发技术,如何快速学习笔记?
    随着互联网的迅速发展,越来越多的企业开始选择GO语言作为其开发语言,因为GO语言具有高效、快速、可靠等特点。但是,很多人在学习GO语言时都遇到了一些困难,因此如何快速学习GO语言实时开发技术,是我们需要探讨的问题。本文将介绍一些GO语言实...
    99+
    2023-11-12
    实时 开发技术 学习笔记
  • Python和LeetCode学习笔记:学习分布式系统开发的必备工具?
    随着科技的不断进步,分布式系统的开发越来越受到重视。而要成为一名优秀的分布式系统开发人员,需要有一定的Python编程基础和LeetCode算法经验。本篇文章将介绍Python和LeetCode在分布式系统开发中的重要性,并为读者提供一些...
    99+
    2023-08-28
    leetcode 学习笔记 分布式
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作