码农知识堂 - 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

  • 相关阅读:
    大数据必看:大厂十年架构师职业生涯实战经验总结,《大规模分布式系统架构与设计实战》
    简单讲解SDL 互斥锁和信号量
    web3.0链游农民世界开发搭建0撸狼人杀玩法模式定制开发
    深度学习-神经网络原理-39
    select、poll、epoll三种IO多路复用的区别
    go开发之个微机器人的二次开发
    <Vue>使用依赖注入的方式共享数据
    docker安装开发常用软件MySQL,Redis,rabbitMQ
    Spring七大组件
    基于GIS与地质灾害易发性评价—信息量模型
  • 原文地址: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号