【vue2第十八章】VueRouter 路由嵌套 与 keep-alive缓存组件(activated,deactivated)

2023-09-22 13:13:26

VueRouter 路由嵌套

在使用vue开发中,可能会碰到使用多层级别的路由。比如:
在这里插入图片描述
其中就包含了两个主要页面,首页,详情,但是首页的下面又包含了列表,喜欢,收藏,我的四个子路由。
在这里插入图片描述
此时就需要配置子路由通过使用children

import Vue from 'vue'
import App from './App.vue'
import MyDetail from './views/MyDetail.vue'
import MyFriend from './views/MyFriend.vue'
import MyIndex from './views/MyIndex.vue'
import MyLike from './views/MyLike.vue'

import VueRouter from 'vue-router'
Vue.use(VueRouter)

Vue.config.productionTip = false

const router = new VueRouter({
  routes: [
  //两个主要页面详情和首页
    {
      path: "/MyIndex", 
      component: MyIndex, 
      //添加children值数组,继续写组件和路径
      children: [
        { path: "/friend", component: MyFriend },
        { path: "/like", component: MyLike }
      ]
    },
    { path: "/MyDetail", component: MyDetail }
  ]
});
new Vue({
  render: h => h(App),
  router
}).$mount('#app')

keep-alive缓存组件

在这里插入图片描述
问题就是在浏览页面的时候,已经将页面下滑了,然后点击到了某一个文章的详情页,最后返回到文章目录时又回到了最顶部,就比如我们刷抖音,我们往下刷,看到一个比较有意思的视频博主,点进去看主页,然后返回回来结果给我返回到了打开抖音的第一个视频。

所以我们在其中可以使用keep-alive标签解决此问题:
在这里插入图片描述
直接使用keep-alive包含需要缓存的组件出口,

其中他有三个属性:

include : 组件名数组,只有匹配的组件会被缓存。

exclude:组件名数组,任何匹配的组件都不会被缓存。

max :最多可以缓存多少组件实例。

使用如下:

<template>
  <div class="h5-wrapper">
  	//include的参数是一个组件名称数组。
    <keep-alive include="[index]"  max="1">
      <router-view></router-view>
    </keep-alive>
  </div>
</template>

<script>
export default {
  name: "h5-wrapper",
}
</script>

keep-alive的使用会触发两个生命周期函数(了解)

activated 当组件被激活 (使用)的时候触发>进入页面触发

deactivated 当组件不被使用的时候触发>离开页面触发

在被缓存的组件下面就可以使用:

<template>
  <div class="h5-wrapper">
    <div class="content">
      内容
    </div>
    <nav class="tabbar">
      <a href="#/article">面经</a>
      <a href="#/collect">收藏</a>
      <a href="#/like">喜欢</a>
      <a href="#/user">我的</a>
    </nav>
  </div>
</template>

<script>
export default {
  name: "LayoutPage",
  //进入页面时触发
  activated(){
    alert("欢迎来到首页")
  },
  //离开页面时触发
  deactivated(){

  }
}
</script>
更多推荐

SENSORO 城市数字化服务平台入围2023《财富》中国最佳设计榜

9月20日,《财富》杂志2023中国最佳设计榜揭晓,SENSORO城市智能感知服务平台荣登榜单。“这是数字政务与数字城市的新尝试”,《财富》评价称。这也是今年软件/平台类目的唯一上榜。数十年前,设计还主要体现于产品美学;到了今天,设计已成为商业模式创新和社会变革的起点。《财富》中国最佳设计榜就试图寻找那些从人的真实需求

tensorflow的unet模型

importtensorflowastffromtensorflow.keras.layersimportInput,Conv2D,MaxPooling2D,Dropout,UpSampling2D,concatenate#定义U-Net模型defunet(input_size=(256,256,3)):inputs=

正则表达式

正则表达式参考文章@CUGGZ参考文章@轩陌声明一个正则表达式字面量声明constrex=/pattern/;构造函数声明constrex=newRegExp(pattern);匹配模式字符集合[]可以匹配中括号中包含的任意字符比如想要匹配btctletrex=/[bc]t/g;letstring="actionbat

SVN 和 GIT 命令对比

参考https://blog.csdn.net/justry_deng/article/details/82259470#TortoiseSVN打分支、合并分支、切换分支https://www.huliujia.com/blog/802a64152bbbe877c95c84ef2fdf3857a056b536/#版本控

机器学习——奇异值分解(未完)

开坑,刚看完书,已经有些窒息了先把坑挖了,再慢慢填,避免自己划水跳过我爱线代,线代爱我,阿弥陀佛为什么要学奇异值分解?因为书本倒数第二章专门提到的,想必一定很重要,于是我上网查了一下奇异值分解的应用wow。。。很有用,增加了学习的动力奇异值分解的应用在机器学习中,奇异值分解,可以删除一些没什么作用的特征。具体是如何删除

JVM——6.字节码指令

这篇文章我们来学习一下字节码指令目录1.简介2.字节码与数据类型3.加载与存储指令4.运算指令5.类型转换指令6.对象创建于访问指令7.操作数栈管理指令8.控制转移指令9.方法调用与返回指令10.异常处理指令11.同步指令12.小结1.简介Java虚拟机的指令由一个字节长度的、代表着某种特定操作含义的数字(称为操作码)

在微信公众号怎么做电子优惠券功能

在微信公众号上,商家可以提供电子优惠券功能来吸引更多的消费者关注并参与,同时提高产品的知名度和销售额。下面是一篇关于如何在微信公众号上实现电子优惠券功能的文章,供您参考。一、了解电子优惠券的定义和优势电子优惠券是一种以电子形式发放的优惠凭证,商家通过微信公众号向消费者发放电子优惠券,消费者在购买指定商品或服务时使用,可

一遍关于vue基础语法上篇

目录一.插值1.1.文本1.2.html1.2.3.属性1.1.4.表达式演示效果:二.指令2.1.v-if/v-else-if/v-else2.2.v-show2.3.v-for2.4.v-bindv-onv-model2.5.动态参数演示效果:三.过滤器3.1.局部过滤器基本应用3.2.局部过滤器串行使用3.3.局

千呼万唤openGauss资源池化系列培训来了

应openGauss广大用户要求,社区于近期推出openGauss资源池化培训系列。关于资源池化资源池化是openGauss5.0.0推出的重点特性,是openGauss基于内存池化和共享存储实现的数据库集群。数据在集群的计算节点内存、共享存储中实现共享。应用可以任意节点接入,集群可以保证提供实时一致性的数据。集群也保

Linux设备驱动之IIC驱动

Linux设备驱动之I2C驱动I2C是一种半双工串行通信总线,使用多主从架构,总线上会挂载设备,设备通信就会涉及协议,下面一起看看I2C通信协议是怎样的,在Linux系统上软件又是如何驱动的。I2C通信协议硬件连接I2C串行总线一般有两根信号线,一根是双向数据线SDA,另一根是时钟线SCL,数据线即用来表示数据,时钟线

华为以太网接口配置命令

【微|信|公|众|号:厦门微思网络】今天给大家带来的命令列表如下:amisolateautoduplexautospeedclock(以太接口视图)combo-portdisplayerror-downrecoverydisplayinterfaceethernetbriefdisplayport-groupdispl

热文推荐