computed计算属性、watch侦听器、生命周期

news2024/11/27 18:45:57

计算属性

点击查看 Vue文档

基础语法

多次使用计算属性,计算属性方法也只执行一次,
调用计算属性的方法不能加()
在这里插入图片描述

直接修改计算数学的值

计算属性不能通过双向绑定修改(默认不能改)
想要修改计算属性,就必须使用计算属性的完整写法

完整写法
计算属性:{
//计算属性默认只有get,在需要的时候添加set()
get(){
return 结果
},
ser(val){
//val就是修改后的计算属性
}
}
使用计算属性筛选输入框数据举例

计算属性是基于它们的响应式依赖进行缓存的。只在相关响应式依赖发生改变时它们才会重新求值。这就意味着只要 message 还没有发生改变,多次访问 reversedMessage 计算属性会立即返回之前的计算结果,而不必再次执行函数。

<input v-model="message" />
//records2是计算属性未在data中定义
<li  v-for="item in records2"></li>
data(){
return {
messgae:''record:{[],[]...}//展示的数据
}
}
computed:{
records2(){
//这里的record2依赖于this.message
if(this.message==='')
{return this.records}
else{
//当
return this.records.filter(item=>item.docotor===this.keywords)
}
}
}

watch侦听器

作用:侦听数据变化,执行一些业务逻辑或异步操作
如果监听对象中的属性,不能直接当函数名,需要加上引号
在这里插入图片描述
监听from、q、to变化时,都要重新翻译,则可以直接监听一个对象
在这里插入图片描述

watch:{
数据:{
handler(变化后的值,变化前的值)
},
deep:true ,//加入改配置,表示深度监听:当对象的任意属性值改变后,都可以侦听到
immediate:true//立即侦听(页面刷新,马上执行一次handler函数)
}
watch的两种写法
函数
	watch:{
		watchData(newValue,oldValue){
			//newValue时属性变化后的值,oldValue是属性变化前的值
			//对应的操作...
		}
	}
	对象
	watch:{
		watchData:{
            handler: function(newValue, oldValue) {
            	//newValue时属性变化后的值,oldValue是属性变化前的值
                // 对应的操作...
            } 
		}
	}
	
watch还有立即监听和深度监听

生命周期

在这里插入图片描述

Vue生命周期函数(钩子函数)自动执行的函数

每个阶段对应两个钩子函数
在这里插入图片描述

<div id="app">
        <h2>{{title}}</h2>
        <button @click="count--">-</button>
        <span>{{count}}</span><button @click="count++">+</button>
    </div>

    <script src="../utils/vue.js"></script>


    <script>
        const vm = new Vue({
            el: '#app',
            data: {
                title: '钩子函数演示',
                count: 100
            },
            // 创建阶段
            beforeCreate() {
                console.log('beforeCreate:', this.count); //此时还不能使用data数据以及调用methods方法
            },
            created() {
                console.log('created:', this.count); //此时可以使用data数据,可以调用methods方法
            },
            // 挂在阶段
            beforeMount() {
                console.log('beforeMount:', document.querySelector('h2'));

            },
            mounted() {
                console.log('beforeMount:', document.querySelector('h2'));
            },
            // 更新阶段(数据更新才触发)
            beforeUpdate() {
                // 数据更新了但是页面还没有更新
                console.log('beforeUpdated:', this.count, document.querySelector('span').innerHTML);
            },
            updated() {
                // 数据、页面都更新
                console.log('updated:', this.count, document.querySelector('span').innerHTML);
            }
        })


    </script>

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1562806.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

如何防止亚马逊账户关联问题?

亚马逊风险控制是亚马逊为了防止买家账户欺诈而实施的规则。具体的风险控制算法是亚马逊技术部门的少数人所独有的&#xff0c;因此我们难以获知其中的细节。为了提高销量&#xff0c;一些卖家可能会采取一些措施&#xff0c;但是由于风控措施的严格&#xff0c;许多卖家深感头…

使用CMake搭建简单的Qt程序

目录结构 代码 CMakeLists.txt&#xff1a; cmake_minimum_required(VERSION 3.15)set(CMAKE_AUTOUIC ON) set(CMAKE_AUTOMOC ON) set(CMAKE_AUTORCC ON)# set the project name project(xxx)# 设置Qt的路径 # 例如 E:/Qt/Qt/aaa/msvc2019_64 # aaa 为Qt的版本号 set(QT_PATH…

如何生成一个指定长度的空数组?

简便写法&#xff1a;使用constructor构造函数进行创建&#xff0c;第一个空数组 [ ] 表示创建一个空数组&#xff0c;然后调用 constructor 属性并传入参数指定数组长度。 [].constructor(17)可用于遍历&#xff0c;例如使用ngFor进行单纯的遍历&#xff0c;参数为遍历次数。

常见的设备通讯协议分析

不同的通信协议根据其设计目的和应用场景&#xff0c;各有其优缺点。在选择通信协议时&#xff0c;需要根据具体的应用需求和场景&#xff0c;权衡各种协议的优缺点&#xff0c;选择最适合的协议。例如&#xff0c;对于实时性要求高的工业控制系统&#xff0c;可能会选择CAN或M…

GWO-CNN-BiLSTM多输入时序预测|灰狼群算法优化的卷积-双向长短期神经网络|Matlab

目录 一、程序及算法内容介绍&#xff1a; 基本内容&#xff1a; 亮点与优势&#xff1a; 二、实际运行效果&#xff1a; 三、算法介绍&#xff1a; 四、完整程序下载&#xff1a; 一、程序及算法内容介绍&#xff1a; 基本内容&#xff1a; 本代码基于Matlab平台编译&…

【Leetcode每日一题】 动态规划 - 不同路径(难度⭐⭐)(49)

1. 题目解析 题目链接&#xff1a;63. 不同路径 II 这个问题的理解其实相当简单&#xff0c;只需看一下示例&#xff0c;基本就能明白其含义了。 2.算法原理 这个问题就像是在一个迷宫中找路&#xff0c;只不过这个迷宫有些格子是不能走的&#xff0c;也就是那些“障碍物”。…

简单几步轻松实现电脑快速切换IP地址

在数字化时代&#xff0c;网络已经成为我们日常生活和工作中不可或缺的一部分。IP地址作为网络设备的标识符&#xff0c;扮演着至关重要的角色。然而&#xff0c;在某些特定场景下&#xff0c;我们可能需要快速切换IP地址&#xff0c;以满足不同的网络需求或保护个人隐私。虎观…

算法基础--递归

&#x1f600;前言 递归是一种重要的算法思想&#xff0c;常用于解决问题的分解与求解。在计算机科学中&#xff0c;递归是指一个函数在其定义中调用自身的情况。 &#x1f3e0;个人主页&#xff1a;尘觉主页 文章目录 算法基础--递归递归入门例题递归实现指数型枚举递归实现排…

gulp的基本使用(一)

gulp的基本使用 开始全局安装gulp-cli本地项目初始化gulp插件的安装查看是否安装成功项目根目录创建gulpfile.js文件运行命令测试结果 开始 全局安装gulp-cli 命令 npm install --global gulp-cligulp-cli作用&#xff1a; gulp的命令行工具&#xff0c;它需要全局安装&…

华为交换机维护——管理接口

常见的设备管理方式有SNMP、Web、Telnet以及通过Console口管理等。从技术的角度分析&#xff0c;网络管理可分为带外管理和带内管理。所谓带内管理&#xff0c;是指网络中的管理数据和业务数据在相同的链路中传输。当管理数据的流量较少时&#xff0c;对整个网络的性能影响不明…

前后端开发之——文章分类管理

原文地址&#xff1a;前后端开发之——文章分类管理 - Pleasure的博客 下面是正文内容&#xff1a; 前言 上回书说到 文章管理系统之添加文章分类。就是通过点击“新建文章分类”按钮从而在服务端数据库中增加一个文章分类。 对于文章分类这个对象&#xff0c;增删改查属于配…

Windows提权—数据库提权-mysql提权mssql提权Oracle数据库提权

目录 Windows 提权—数据库提权一、mysql提权1.1 udf提权1.1.2 操作方法一 、MSF自动化--UDF提权--漏洞利用1.1.3 操作方法二、 手工导出sqlmap中的dll1.1.4 操作方法三、 moon.php大马利用 1.2 mof提权1.3 启动项提权1.4 反弹shell 二、MSSQL提权MSSQL提权方法1.使用xp_cmdshe…

项目管理工具的魔力:团队合作的秘诀大揭秘!

我们知道项目的成败往往取决于人。假如一个项目团队组织不善&#xff0c;即使项目经理能力很强也无法力挽狂澜&#xff0c;甚至被团队束缚。创建更好的项目团队可以从多方面下手其中项目管理工具就是重要的一项&#xff0c;如何利用项目管理工具组建更好的项目团队&#xff1f;…

中国主要河流水系数据

在我国&#xff0c;水系等级划分主要依据流域面积、流量和河流长度等因素。根据《中华人民共和国水资源》的相关规定&#xff0c;我国水系等级大致可以分为以下几类&#xff1a; 一级水系&#xff1a;主要是指国内的大型河流&#xff0c;如长江、黄河、珠江等。这些河流的流域…

java入门-分支与循环

分支结构 分支结构是解决程序选取分支走不同的路线&#xff0c;增加了程序开发的灵活性。java的分支主要由if和switch这两种结构实现。 if 语句 if是分支中最常用的语法&#xff0c;它从形式上有三种形态&#xff1a; if 结构 结构 语法 if(表达式){ //代码块 } 程序案例 i…

基于java+SpringBoot+Vue的学生考勤管理系统设计与实现

基于javaSpringBootVue的学生考勤管理系统设计与实现 开发语言: Java 数据库: MySQL技术: SpringBoot MyBatis工具: IDEA/Eclipse、Navicat、Maven 系统展示 前台展示 登录注册&#xff1a;支持学生、教师和管理员登录和注册。 个人中心&#xff1a;用户可以查看和更新个…

C语言-冒泡排序算法

题目描述 设计一个程序&#xff0c;实现冒泡排序算法&#xff0c;并输出{9,8,7,6,5,4,3,2,1,0} 的排序过程。 输出 每个排序过程输出一行&#xff0c;直到排序完成。 样例输出 Expected 9 8 7 6 5 4 3 2 1 0 0 9 8 7 6 5 4 3 2 1 0 1 9 …

C#学习笔记7:C#面向对象编程方法(1)

今日继续我的C#学习笔记 主要用实际代码编程来学习研究C#面向对象的编程方法&#xff1a;直接看代码及注释即可&#xff1a; 目录 1、对类与对象概念的快速认知&#xff1a; 2、类和对象成员访问控制&#xff1a; 3、类的构造函数和析构函数&#xff1a; 4、类的属性&#xff…

GaussDB云数据库极简版安装与使用-新手指南

一、前言 作为一款领先的企业级数据库管理系统&#xff0c;GaussDB 提供了强大的性能、高度可靠性和丰富的功能&#xff0c;是企业构建可靠、高性能的数据库解决方案的理想选择。 本文主要针对高校和个人测试环境&#xff0c;介绍极简版安装和使用过程&#xff0c;更加适合高…

git 修改历史 commit message

目录 1&#xff0c;修改当前的2&#xff0c;修改历史的1&#xff0c;先查看 log2&#xff0c;开始修改 3&#xff0c;其他注意点1&#xff0c;中途不想修改了2&#xff0c;commit ID 会发生变化3&#xff0c;推送远程4&#xff0c;精准定位 1&#xff0c;修改当前的 直接使用下…