码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • Vue--Router--<router-view :key=“keyName“/>中key的作用


    原文网址:Vue--Router--<router-view :key=“keyName“/>中key的作用_IT利刃出鞘的博客-CSDN博客

    简介

    说明

            本文介绍<router-view :key=“key“/>中key的作用。

            Vue会复用相同组件,对于路由有多个子路由来说,当在子路由来回切换时,会导致页面不刷新的问题,因为不再执行created和mounted这些钩子函数。本文介绍的中的key即可解决这个问题。

    官网网址

    https://vuejs.bootcss.com/guide/conditional.html#用-key-管理可复用的元素

    官网里边有一句:Vue 为你提供了一种方式来表达“这两个元素是完全独立的,不要复用它们”。只需添加一个具有唯一值的 key attribute 即可

    缺点

            加了路由的key值,Vue就会认为这不是同一个组件,update的时候会删除这个组件再重新加载一个新的组件,有严重的性能问题。比如:在后台系统中,点击侧导航菜单子菜单时,设置了:key="$route.path"会导致菜单关闭又打开,视觉效果不好。

    代码示例

    1. <template>
    2. <section class="app-main">
    3. <transition name="fade-transform" mode="out-in">
    4. <router-view :key="key" />
    5. transition>
    6. section>
    7. template>
    8. <script>
    9. export default {
    10. name: 'AppMain',
    11. computed: {
    12. key() {
    13. return this.$route.fullPath
    14. }
    15. }
    16. }
    17. script>

    1. 不设置key 属性

            Vue 会复用相同组件, 即: /page/1 => /page/2 或者 /page?id=1 => /page?id=2 这类链接跳转时, 不执行created, mounted之类的钩子, 这时候你需要在路由组件中添加beforeRouteUpdate钩子来执行相关方法拉去数据

    相关钩子函数为: beforeRouteUpdate

    2. 设置 key 属性值为 $route.path

    /page/1 => /page/2

    由于这两个路由的$route.path不一样, 所以组件被强制不复用, 相关钩子加载顺序为:

    beforeRouteUpdate => created => mounted

    /page?id=1 => /page?id=2,

    由于这两个路由的$route.path一样, 所以和没设置 key 属性一样, 会复用组件, 相关钩子加载顺序为:

    beforeRouteUpdate

    3. 设置 key 属性值为 $route.fullPath

    /page/1 => /page/2

            由于这两个路由的$route.fullPath不一样, 所以组件被强制不复用, 相关钩子加载顺序为:
    beforeRouteUpdate => created => mounted

    /page?id=1 => /page?id=2

            由于这两个路由的$route.fullPath不一样, 所以组件被强制不复用, 相关钩子加载顺序为:
    beforeRouteUpdate => created => mounted

  • 相关阅读:
    《Nature》论文插图的Matlab复刻第4期—单组多色柱状图(Part2-82)
    从 HPC 到 AI:探索文件系统的发展及性能评估
    7. CSS 网格布局
    c语言实现三子棋
    【数据结构初阶】七、非线性表里的二叉树(堆的实现 -- C语言顺序结构)
    NVIDIA 安装 CUDA
    【单目3D目标检测】FCOS3D + PGD论文解析与代码复现
    Java -Version的秘密
    NuGet打包类库并上传教程
    Effective C++ 学习笔记 条款22 将成员变量声明为private
  • 原文地址:https://blog.csdn.net/feiying0canglang/article/details/126273586
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号