vue 中 keep-alive,activated,deactivated

article/2025/9/23 7:28:45

keep-alive

        在组件反复切换时,会反复渲染,造成性能问题。用一个 <keep-alive></keep-alive> 标签将他包裹起来,组件会在第一次被创建的时候缓存下来。避免性能问题。

        首先准备好组件,配置好路由。准备了Home,Keep,About三个组件进行切换。

App.vue

<template><div id="app"><div id="nav"><router-link to="/">Home</router-link> |<router-link to="/keep">Keep</router-link> |<router-link to="/about">About</router-link></div><keep-alive><router-view /></keep-alive></div>
</template>
<script>
export default {data() {return {};},
};
</script><style lang="less">
</style>

Keep.vue

<template><div><ul><li v-for="post in posts" :key="post.id" @click="selectedPost = post">{{ post.title }}</li></ul><div><div v-if="selectedPost"><h3>{{ selectedPost.title }}</h3><div v-html="selectedPost.content"></div></div><strong v-else> 点击标签 </strong></div></div>
</template>
<script>
export default {data() {return {posts: [{id: 1,title: "第一个标签",content: "第一个标签内容",},{id: 2,title: "第二个标签",content: "第二个标签内容"},{id: 3,title: "第三个标签",content: "第三个标签内容"},],selectedPost: null,};},created() {console.log('created');},activated() {console.log('activated');},mounted() {console.log('mounted');}
};
</script>

 

 

         在Keep组件中有三个标签,点击标签会变成

         如果不加<keep-alive></keep-alive> 标签,跳转到其他组件再跳转回Keep组件时,之前选择的内容不会被缓存,会显示

 

         加<keep-alive></keep-alive> 标签,再次跳转回来时,之前缓存的内容会被保存。

activated

        被 keep-alive 缓存的组件激活时调用。该钩子在服务器端渲染期间不被调用。

        在不加<keep-alive></keep-alive> 标签时,并不会调用activated:

        加上<keep-alive></keep-alive> 标签时,created和mounted钩子函数只会调用一次,每次切换到Keep组件,都会执行activated:

 

 deactivated

        被 keep-alive 缓存的组件失活时调用。该钩子在服务器端渲染期间不被调用。


http://chatgpt.dhexx.cn/article/ArkSZX0N.shtml

相关文章

【Vue】学习笔记-Vue Router activated deactivated 路由守卫

Vue Router activated deactivated 路由守卫 activated deactivated路由守卫1.全局守卫2.独享守卫3.组件内守卫全局路由守卫路由器的两种工作模式 activated deactivated activated 和 deactivated 是路由组件所独有的两个钩子&#xff0c;用于捕获路由组件的激活状态 具体使用…

vue 生命周期图 + activated + deactivated

一、vue 生命周期图 From the network 二、activated deactivated 除此之外&#xff0c;简单介绍一下在被keep-alive包含的组件/路由中&#xff0c;会多出两个生命周期的钩子:activated 与 deactivated。在 2.2.0 及其更高版本中&#xff0c;activated 和 deactivated 将会…

[Vue]缓存路由组件 activated()与deactivated()

前言 系列文章目录&#xff1a; [Vue]目录 老师的课件笔记&#xff0c;不含视频 https://www.aliyundrive.com/s/B8sDe5u56BU 笔记在线版&#xff1a; https://note.youdao.com/s/5vP46EPC 视频&#xff1a;尚硅谷Vue2.0Vue3.0全套教程丨vuejs从入门到精通 文章目录 前言1. 缓存…

Vue 钩子函数activated未触发

activated()和deactivated()只有在<keep-alive></keep-alive>包裹的时候才有效&#xff1b;

搞明白activated和deactivated

文章目录 写到前面什么是activatedactivated解决了一个什么问题Demomain.vueassembly1(组件1)assembly2(组件2) 执行结果要点速记个人建议写到最后 写到前面 今天简单的将activated讲一下&#xff0c;前面有人问了&#xff0c;既然有问的&#xff0c;说明还有人不是很明白的&am…

vue中activated

keep-alive <keep-alive>包裹动态组件的时候&#xff0c;会缓存不活动的组件实例&#xff0c;而不是摧毁他们。其是一个抽象的组件&#xff0c;自身不会渲染一个DOM元素&#xff0c;也不会出现在父组件链中。 说白了被<keep-alive>包裹的组件其会被缓存。 没有被…

Vue学习之---动态组件中的activated与deactivated钩子函数

Vue学习之—动态组件中的activated与deactivated钩子函数 在学习这两个钩子函数之前呢&#xff0c;怎么需要先了解下Vue内置的动态组件< component >以及与之相配套的< keep-alive > 组件&#xff1a; 动态组件指的是动态切换组件的显示与隐藏&#xff1b; < …

vue中keep-alive、activated的探讨和使用

在修改公司的一个项目的时候发现了activated这个东西&#xff0c;一直觉得很疑惑&#xff0c;之前也没怎么用过啊&#xff01;官网的生命周期那也没说过这东西啊&#xff01;生命周期不就create mount update 和destory这几个东东么&#xff0c;怎么多了个activate出来。 百思不…

html页面ajax提交数据,ajax请求提交form表单

AJAX表单提交以及数据接收 方式一 手工收集所有的用户输入&#xff0c;封装为大的“k1v1&k2v2…”键值对形式&#xff0c;使用$.post(url, data,fn)把数据提交给服务器 $.ajax({ type:post, url:Notice_noTipsNotice, data:k1v1&k2v2..., cache:false, dataType:json, …

接上篇 jquery.form.js 的 $.ajaxForm()和 $.ajaxSubmit()

2019独角兽企业重金招聘Python工程师标准>>> AjaxSubmit 和AjaxForm区别 AjaxForm ajaxForm()不能提交表单。在document的ready函数中&#xff0c;使用ajaxForm来为AJAX提交表单进行准备。提交动作必须由submit开始 , ajaxForm()适用于以表单提交方式处理ajax技术&a…

springboot ajax form json 请求方式

1.form请求的后台代码 1.定义实体 Student package com.bsx.test.entity;import com.bsx.test.constant.Gender; import com.bsx.test.constant.Nature;import javax.persistence.Column; import javax.persistence.Id; import javax.persistence.Table; import java.io.Seri…

ajax form表单提交 input file中的文件

现今的主流浏览器由于ajax提交form表单无法把文件类型数据提交到后台&#xff0c;供后台处理&#xff0c;可是开发中由于某些原因又不得不用ajax提交文件&#xff0c; 为了解决这个问题我走了不少弯路&#xff1a; 1、用原生的 input file &#xff0c; 不支持ajax上传文件&…

Jquery 中 ajaxSubmit 、ajaxForm使用讲解

最近在使用ajaxForm&#xff0c;随便把使用方法记下下来&#xff0c;以便以后回顾。 1 &#xff0c;引入依赖脚本 <script type"text/JavaScript" src"/js/jQuery/jquery.form.js"></script> //ajaxForm 依赖脚本 <script type"…

ajaxForm 与ajaxSubmit

ajaxSubmit 和ajaxForm区别 ajaxForm ajaxForm()不能提交表单。在document的ready函数中&#xff0c;使用ajaxForm来为AJAX提交表单进行准备。提交动作必须由submit开始 ajaxForm()适用于以表单提交方式处理ajax技术&#xff08;需要提供表单的action、id、 method&#xff0…

前后端交互之使用ajax方法实现form表单的提交

转载于&#xff1a;使用ajax方法实现form表单的提交 - 程序员十三 - 博客园 (cnblogs.com) οnsubmit“reutrn false”&#xff1a;表示禁止表单提交。 data: $(#addTaskform).serialize(),序列化提交表单数据。 不要忘记引用js文件 <script type"text/javascript&…

一文必懂-Ajax与form

Restful与Ajax Ajax示例1:查询所有学生数据示例2&#xff1a;查找部分学生数据中文传参 表单标签抓包数据 Post与GetRestful示例Restful附带URL参数 Ajax与form标签 Ajax 一种在网页上调用后台接口的方式 jquery提供了相应的用法 即 $.ajax({内容});先添加jQuery包。 内容部分…

手把手教你开发一款属于自己的Arduino开发板

【前言】 相信很多小伙伴们手里都一块或者几块开发板吧&#xff0c;没有没想过自己也开发一款开发板呢&#xff1f;接下来就教你开发一款属于自己的开发板吧(●◡●)。 【软件版本】 AD17 【正文】 1. 硬件选型 1.1 主控芯片&#xff1a;用ATMEGA32P吧&#xff0c;用LQFP封…

Arduino IDE 离线添加开发板

目录 问题背景配置环境配置方法在线方法&#xff08;失败&#xff09;离线方法&#xff08;成功&#xff09; 其他开发板参考资料 问题背景 想要使用ESP32-S2开发板&#xff0c;搭建一个小项目&#xff0c;目前比较主流的编程方法有三种&#xff0c;一种是IDF&#xff08;应该…

Arduino nano开发板选购

介绍两块Arduino nano开发板&#xff0c;串口芯片都是ch340g&#xff0c;黑色的采用Atmega168p&#xff0c;粉色的采用Atmega328p。板子挺厚的而且都是type c接口&#xff0c;有黑色和粉色可选。 除了主控芯片不同&#xff0c;其他都一样&#xff0c;只需要在Arduino程序中将处…

配置esp8266开发板的Arduino开发环境

1.esp8266开发板硬件&#xff1a; 基于esp8266的nodemuc开发板&#xff08;pdd上有卖不超过15块&#xff09;&#xff1b;microUSB数据线&#xff08;这里一定要是数据线&#xff0c;具备数据传输和充电功能&#xff0c;不能仅充电&#xff09;。 esp8266开发环境有许多例如&a…