[{"data":1,"prerenderedAt":3564},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter":886},[4,8,12,16,20,24,28,32,36,40,44,48,52,56,60,64,68,72,76,80,84,88,92,96,100,104,108,112,116,120,124,128,132,136,140,144,148,152,156,159,162,165,169,172,175,178,182,186,190,194,198,202,206,210,214,218,222,226,230,234,238,242,246,250,254,258,262,266,269,273,277,281,285,288,291,294,298,301,304,307,310,313,316,319,322,325,329,332,336,340,344,348,352,356,359,362,365,368,371,374,377,380,383,386,389,393,396,399,402,405,408,411,414,417,420,424,428,432,435,438,442,446,450,454,458,462,466,470,474,477,480,483,487,491,494,497,500,504,507,511,515,518,521,524,527,530,533,536,539,542,545,548,551,554,557,560,563,566,569,572,575,579,583,587,591,595,599,603,606,610,614,617,620,623,626,629,633,637,640,643,646,649,652,655,658,661,664,667,670,673,676,679,682,685,688,691,694,697,700,703,706,709,712,716,720,724,728,732,736,740,744,748,752,756,760,764,768,772,775,779,783,787,790,793,796,799,802,805,808,811,814,818,822,825,829,832,835,838,841,844,848,851,854,858,862,865,869,873,876,879,882],{"path":5,"title":6,"description":7},"\u002Fabout\u002Fauthor","作者相关","只想纯粹的做一个程序员...",{"path":9,"title":10,"description":11},"\u002Fabout\u002Fjourney","心路历程","",{"path":13,"title":14,"description":15},"\u002Fai\u002Fagent\u002Fframeworks","Agent 框架","主流 Agent 框架：LangChain、LlamaIndex、AutoGen、CrewAI",{"path":17,"title":18,"description":19},"\u002Fai\u002Fagent\u002Fhooks","Agent Hooks 与自动化","Claude Agent 的 Hooks 生命周期、事件类型、典型自动化场景",{"path":21,"title":22,"description":23},"\u002Fai\u002Fagent\u002Fintroduction","AI Agent 概述","AI Agent 核心概念：感知、规划、执行、记忆",{"path":25,"title":26,"description":27},"\u002Fai\u002Fagent\u002Fpractice","Agent 实战","AI Agent 实战：构建自主任务执行系统",{"path":29,"title":30,"description":31},"\u002Fai\u002Fagent\u002Fsdk","Claude Agent SDK 开发","使用 Claude Agent SDK 构建自定义 AI Agent：架构、API、生命周期",{"path":33,"title":34,"description":35},"\u002Fai\u002Fagent\u002Fsubagents","Subagents 子代理","用 Subagents 分解复杂任务、并发执行、隔离上下文",{"path":37,"title":38,"description":39},"\u002Fai\u002Fagent\u002Ftool-use","工具调用","AI Agent 工具调用：Function Calling、Tool Use 原理与实践",{"path":41,"title":42,"description":43},"\u002Fai\u002Ffundamentals\u002Fdeep-learning","深度学习入门","深度学习基础知识：前向传播、反向传播、损失函数、优化器",{"path":45,"title":46,"description":47},"\u002Fai\u002Ffundamentals\u002Fml-basics","机器学习基础","机器学习核心概念：监督学习、无监督学习、强化学习",{"path":49,"title":50,"description":51},"\u002Fai\u002Ffundamentals\u002Fneural-networks","神经网络原理","神经网络架构：CNN、RNN、注意力机制",{"path":53,"title":54,"description":55},"\u002Fai\u002Fgetting-started","AI 学习路线","AI 技术学习路线图，从基础到实战的完整指南",{"path":57,"title":58,"description":59},"\u002Fai\u002Fllm\u002Ffine-tuning","模型微调","大模型微调技术：LoRA、QLoRA、全量微调、RLHF",{"path":61,"title":62,"description":63},"\u002Fai\u002Fllm\u002Fintroduction","大模型概述","大语言模型发展历程、核心能力与主流模型对比",{"path":65,"title":66,"description":67},"\u002Fai\u002Fllm\u002Flocal-deploy","本地部署","大模型本地部署：Ollama、vLLM、llama.cpp",{"path":69,"title":70,"description":71},"\u002Fai\u002Fllm\u002Ftransformer","Transformer 架构","Transformer 架构详解：自注意力机制、位置编码、多头注意力",{"path":73,"title":74,"description":75},"\u002Fai\u002Fmcp\u002Fclient","MCP Client 开发","MCP Client 开发指南：连接、调用、集成",{"path":77,"title":78,"description":79},"\u002Fai\u002Fmcp\u002Fdebugging","MCP 调试与排错","MCP Server 开发与集成过程中的常见问题、日志分析、诊断工具",{"path":81,"title":82,"description":83},"\u002Fai\u002Fmcp\u002Fintroduction","MCP 概述","Model Context Protocol 协议概述：架构、核心概念、应用场景",{"path":85,"title":86,"description":87},"\u002Fai\u002Fmcp\u002Fserver","MCP Server 开发","MCP Server 开发指南：资源、工具、提示词的实现",{"path":89,"title":90,"description":91},"\u002Fai\u002Fmcp\u002Ftools","MCP Tools 深入","深入理解 MCP Tools：与 Resources\u002FPrompts 的差异、Schema 设计、Annotations 与权限控制",{"path":93,"title":94,"description":95},"\u002Fai\u002Fprompt\u002Fadvanced","高级 Prompt 模式","高级 Prompt 设计模式：Tree-of-Thought、自我反思、多轮对话策略",{"path":97,"title":98,"description":99},"\u002Fai\u002Fprompt\u002Fbasics","Prompt 基础","Prompt Engineering 入门：基本概念、角色设定、输出格式控制",{"path":101,"title":102,"description":103},"\u002Fai\u002Fprompt\u002Ftechniques","提示词技巧","常用提示词技巧：Few-shot、Chain-of-Thought、ReAct",{"path":105,"title":106,"description":107},"\u002Fai\u002Frag\u002Fembedding","文本嵌入","文本嵌入模型：Embedding 原理、模型选择、相似度计算",{"path":109,"title":110,"description":111},"\u002Fai\u002Frag\u002Fintroduction","RAG 概述","检索增强生成（RAG）架构原理、优势与应用场景",{"path":113,"title":114,"description":115},"\u002Fai\u002Frag\u002Fpractice","RAG 实战","RAG 应用实战：文档问答系统、知识库搭建",{"path":117,"title":118,"description":119},"\u002Fai\u002Frag\u002Fvector-database","向量数据库","主流向量数据库对比：Milvus、Pinecone、Chroma、Weaviate",{"path":121,"title":122,"description":123},"\u002Fai\u002Fskills\u002Fbest-practices","Skill 最佳实践","编写高质量 Skill 的设计原则、常见陷阱与优化技巧",{"path":125,"title":126,"description":127},"\u002Fai\u002Fskills\u002Fcreating","创建自定义 Skill","从零编写一个可被 Agent 自动发现和调用的 Skill",{"path":129,"title":130,"description":131},"\u002Fai\u002Fskills\u002Fintroduction","Agent Skills 概述","Claude Agent Skills 概念、工作原理、与 Tools\u002FMCP 的区别",{"path":133,"title":134,"description":135},"\u002Fgolang\u002Fadvanced\u002Fconcurrency","Go - 并发深入","深入理解 Go 并发编程的核心机制。",{"path":137,"title":138,"description":139},"\u002Fgolang\u002Fadvanced\u002Fgc","Go - 垃圾回收","理解 Go 的垃圾回收机制，掌握 GC 调优方法。",{"path":141,"title":142,"description":143},"\u002Fgolang\u002Fadvanced\u002Fgmp","Go - GMP 调度模型","GMP 是 Go 运行时调度器的核心模型，理解它对于编写高性能 Go 程序至关重要。",{"path":145,"title":146,"description":147},"\u002Fgolang\u002Fadvanced\u002Fgo-concurrency","Go - 并发编程","Go 的并发是其核心特性之一，通过 Goroutine 和 Channel 实现。",{"path":149,"title":150,"description":151},"\u002Fgolang\u002Fadvanced\u002Fmemory","Go - 内存模型","理解 Go 的内存分配机制和内存模型。",{"path":153,"title":154,"description":155},"\u002Fgolang\u002Fadvanced\u002Fprofiling","Go - 性能分析","掌握 Go 的性能分析工具：pprof、trace、benchmark。",{"path":157,"title":158,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-basic","Go - 基础语法",{"path":160,"title":161,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-composite","Go - 复合类型",{"path":163,"title":164,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-control","Go - 流程控制",{"path":166,"title":167,"description":168},"\u002Fgolang\u002Fcore\u002Fgo-error","Go - 错误处理","Go 使用显式的错误返回值来处理错误，而不是异常机制。",{"path":170,"title":171,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-function","Go - 函数",{"path":173,"title":174,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-install","Go - 环境搭建",{"path":176,"title":177,"description":11},"\u002Fgolang\u002Fcore\u002Fgo-interface","Go - 接口",{"path":179,"title":180,"description":181},"\u002Fgolang\u002Fcore\u002Fgo-module","Go - 包管理","Go Modules 是 Go 1.11 引入的官方依赖管理方案，Go 1.16 后成为默认模式。",{"path":183,"title":184,"description":185},"\u002Fgolang\u002Fdistributed\u002Fgrpc","Go - gRPC","gRPC 是 Google 开发的高性能 RPC 框架，使用 Protocol Buffers 作为序列化协议。",{"path":187,"title":188,"description":189},"\u002Fgolang\u002Fdistributed\u002Fmicroservice","Go - 微服务","微服务架构的核心组件：服务发现、负载均衡、熔断降级。",{"path":191,"title":192,"description":193},"\u002Fgolang\u002Fdistributed\u002Fmq","Go - 消息队列","使用 Go 操作 Kafka 和 RabbitMQ。",{"path":195,"title":196,"description":197},"\u002Fgolang\u002Fdistributed\u002Fredis","Go - Redis","使用 go-redis 操作 Redis，实现缓存、分布式锁等功能。",{"path":199,"title":200,"description":201},"\u002Fgolang\u002Fengineering\u002Fconfig","Go - 配置管理","使用 viper 进行配置管理，支持多种配置格式和配置中心。",{"path":203,"title":204,"description":205},"\u002Fgolang\u002Fengineering\u002Fdocker","Go - Docker 部署","使用 Docker 容器化部署 Go 应用。",{"path":207,"title":208,"description":209},"\u002Fgolang\u002Fengineering\u002Fkubernetes","Go - Kubernetes 部署","在 Kubernetes 上部署和管理 Go 应用。",{"path":211,"title":212,"description":213},"\u002Fgolang\u002Fengineering\u002Flogging","Go - 日志系统","使用 zap 和 logrus 构建高性能结构化日志系统。",{"path":215,"title":216,"description":217},"\u002Fgolang\u002Fengineering\u002Ftesting","Go - 单元测试","Go 内置了强大的测试框架，掌握测试是编写高质量代码的基础。",{"path":219,"title":220,"description":221},"\u002Fgolang\u002Fstdlib\u002Fbufio","bufio","在 Go 语言中，bufio 包提供了带缓冲的 I\u002FO 操作，能够提高读写性能。以下是一些常用的 bufio 包 API 及其详细说明：",{"path":223,"title":224,"description":225},"\u002Fgolang\u002Fstdlib\u002Fcontainer","container","在Go语言标准库中，container 包提供了几种常用的数据结构实现，这些数据结构对于高效地管理和操作数据非常有用。以下是 container 包中主要的数据结构：",{"path":227,"title":228,"description":229},"\u002Fgolang\u002Fstdlib\u002Fcrypto","crypto","在 Go 语言中，crypto 包提供了一组用于加密和解密的功能。以下是一些常用的 crypto 包及其子包的 API 及其详细说明：",{"path":231,"title":232,"description":233},"\u002Fgolang\u002Fstdlib\u002Fencoding-csv","encoding\u002Fcsv","在 Go 语言中，encoding\u002Fcsv 包提供了对 CSV（逗号分隔值）文件进行读写的功能。以下是一些常用的 encoding\u002Fcsv 包的 API 及其详细说明：",{"path":235,"title":236,"description":237},"\u002Fgolang\u002Fstdlib\u002Fencoding-json","encoding\u002Fjson","在 Go 语言中，encoding\u002Fjson 包提供了对 JSON 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fjson 包的 API 及其详细说明：",{"path":239,"title":240,"description":241},"\u002Fgolang\u002Fstdlib\u002Fencoding-xml","encoding\u002Fxml","在 Go 语言中，encoding\u002Fxml 包提供了对 XML 数据进行编码和解码的功能。以下是一些常用的 encoding\u002Fxml 包的 API 及其详细说明：",{"path":243,"title":244,"description":245},"\u002Fgolang\u002Fstdlib\u002Fflag","flag","在Go语言中，flag 包是用于处理命令行参数的标准库，它提供了一种简单而直接的方式来解析和使用命令行参数。下面是关于 flag 包的一些基本介绍和常用功能：",{"path":247,"title":248,"description":249},"\u002Fgolang\u002Fstdlib\u002Ffmt","fmt","在 Go 语言的标准库中，fmt 包是非常重要的，它提供了处理格式化输入和输出的基本工具。以下是一些 fmt 包内常用的API：",{"path":251,"title":252,"description":253},"\u002Fgolang\u002Fstdlib\u002Fhttp","net\u002Fhttp","在 Go 语言中，net\u002Fhttp 包提供了用于构建 HTTP 客户端和服务器的强大工具。以下是一些常用的 net\u002Fhttp 包的 API 及其详细说明：",{"path":255,"title":256,"description":257},"\u002Fgolang\u002Fstdlib\u002Fio","io","在 Go 语言中，io 包提供了基本的输入输出功能。以下是一些常用的 io 包的 API 及其详细说明：",{"path":259,"title":260,"description":261},"\u002Fgolang\u002Fstdlib\u002Flog","log","在 Go 语言中，log 包提供了简单的日志记录功能。以下是一些常用的 log 包的 API 及其详细说明：",{"path":263,"title":264,"description":265},"\u002Fgolang\u002Fstdlib\u002Fmath","math","在 Go 语言中，math 包提供了基本的数学函数和常量。以下是一些常用的 math 包的 API 及其详细说明：",{"path":267,"title":268,"description":11},"\u002Fgolang\u002Fstdlib\u002Fnet","net",{"path":270,"title":271,"description":272},"\u002Fgolang\u002Fstdlib\u002Fos","os","在Go语言中，os 包是一个非常重要且常用的标准库，它提供了与操作系统交互的功能，包括文件操作、环境变量管理、进程管理等。下面是一些 os 包中常用的功能和API：",{"path":274,"title":275,"description":276},"\u002Fgolang\u002Fstdlib\u002Fsort","order","在 Go 语言中，sort 包提供了对切片和用户定义的集合进行排序的函数。它实现了常见的排序算法，如快速排序（Quicksort）和堆排序（Heapsort），并且为自定义集合提供了接口，使得用户可以根据特定的需求进行排序。",{"path":278,"title":279,"description":280},"\u002Fgolang\u002Fstdlib\u002Fstrconv","strconv","在 Go 语言中，strconv 包提供了字符串和基本数据类型之间的转换函数，例如将整数转换为字符串、字符串转换为整数，以及其他类型之间的转换。这些功能非常有用，特别是在处理用户输入或从外部数据源读取数据时。",{"path":282,"title":283,"description":284},"\u002Fgolang\u002Fstdlib\u002Ftime","time","在 Go 语言中，time 包提供了处理时间和日期的功能。以下是一些常用的 time 包的 API 及其详细说明：",{"path":286,"title":287,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ferror","Gin - 错误处理",{"path":289,"title":290,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Ffile","Gin - 文件处理",{"path":292,"title":293,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fmiddleware","Gin - 中间件",{"path":295,"title":296,"description":297},"\u002Fgolang\u002Fweb\u002Fgin\u002Fquickstart","Gin - 快速开始","Gin 是目前最流行的 Go Web 框架，以高性能和简洁 API 著称。",{"path":299,"title":300,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frequest","Gin - 请求处理",{"path":302,"title":303,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fresponse","Gin - 响应处理",{"path":305,"title":306,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Frouter","Gin - 路由",{"path":308,"title":309,"description":11},"\u002Fgolang\u002Fweb\u002Fgin\u002Fvalidation","Gin - 参数校验",{"path":311,"title":312,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fassociation","GORM - 关联关系",{"path":314,"title":315,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fcrud","GORM - CRUD 操作",{"path":317,"title":318,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fmodel","GORM - 模型定义",{"path":320,"title":321,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fperformance","GORM - 日志与性能",{"path":323,"title":324,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquery","GORM - 高级查询",{"path":326,"title":327,"description":328},"\u002Fgolang\u002Fweb\u002Fgorm\u002Fquickstart","GORM - 快速开始","GORM 是 Go 语言最流行的 ORM 库，功能强大，使用简单。",{"path":330,"title":331,"description":11},"\u002Fgolang\u002Fweb\u002Fgorm\u002Ftransaction","GORM - 事务与 Hook",{"path":333,"title":334,"description":335},"\u002Finterview\u002Fbasic","计算机基础面经","本章节汇总了面试中常见的通用技术概念，不局限于特定语言或数据库，是考察技术内功的关键考点。",{"path":337,"title":338,"description":339},"\u002Finterview\u002Fgolang","Golang 面试题","Go 语言面试高频考点，覆盖基础语法、数据结构、并发编程、内存管理、GC、调度器等核心知识。",{"path":341,"title":342,"description":343},"\u002Finterview\u002Fk8s","Kubernetes 面试题","Kubernetes（K8s）面试高频考点，覆盖架构原理、核心资源、网络存储、调度策略、运维监控等核心知识。",{"path":345,"title":346,"description":347},"\u002Finterview\u002Fmysql","MySQL 面试题","MySQL 数据库面试高频考点，覆盖索引、事务、锁、优化、主从复制等核心知识。",{"path":349,"title":350,"description":351},"\u002Finterview\u002Fredis","Redis 面试题","Redis 面试高频考点，覆盖数据结构、持久化、集群、缓存一致性、性能优化等核心知识。",{"path":353,"title":354,"description":355},"\u002Finterview\u002Frocketmq","RocketMQ 面试题","RocketMQ 面试高频考点，覆盖消息模型、可靠性、顺序消息、事务消息、存储与高可用等核心知识。",{"path":357,"title":358,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-arraylist","List - ArrayList 源码解析",{"path":360,"title":361,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-linkedlist","List - LinkedList 源码解析",{"path":363,"title":364,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-stack","List - Satck源码解析",{"path":366,"title":367,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Flist-vectore","List - Vector 源码解析",{"path":369,"title":370,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-hashmap","Map - HashMap 源码解析",{"path":372,"title":373,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-linkedhashmap","Map - LinkedHashMap 源码解析",{"path":375,"title":376,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fmap-treemap","Map - TreeMap 源码解析",{"path":378,"title":379,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-deque","Queue - Deque 接口解析",{"path":381,"title":382,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fqueue-queue","Queue - Queue 接口解析",{"path":384,"title":385,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-hashset","Set - HashSet源码解析",{"path":387,"title":388,"description":11},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-linkedhashset","Set - LinkedHashSet 源码解析",{"path":390,"title":391,"description":392},"\u002Fother\u002Fjava\u002Fcollection\u002Fset-treeset","Set - TreeSet源码解析","TreeSet 是一个 Set 集合接口的实现类，与 HashSet 类似，其底层也是通过维护了一个 TreeMap 对象来封装了一些实现方法，故本篇不再对 TreeSet 的底层原理进行详细说明，仅对常用 API 做简单介绍，如需了解 TreeMap 的底层实现原理，请移步 Map - HashMap 源码解析",{"path":394,"title":395,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fannotation","Java核心 - 注解",{"path":397,"title":398,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fbasic-grammar","Java核心 - 基础语法",{"path":400,"title":401,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fclass-and-object","Java核心 - 面向对象",{"path":403,"title":404,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fcommon-classes","Java核心 - 常用类",{"path":406,"title":407,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fexception","Java核心 - 异常处理",{"path":409,"title":410,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fgenerics","Java核心 - 泛型",{"path":412,"title":413,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fjdk-env-path","Java核心 - 环境搭建",{"path":415,"title":416,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Freflection","Java核心 - 反射",{"path":418,"title":419,"description":11},"\u002Fother\u002Fjava\u002Fcore\u002Fstring","Java核心 - String 字符串",{"path":421,"title":422,"description":423},"\u002Fother\u002Fjava\u002Fio\u002Fbuffer-stream","Java IO - 缓冲流","缓冲流是对基本流的包装，通过内置缓冲区减少系统调用次数，大幅提升读写效率。",{"path":425,"title":426,"description":427},"\u002Fother\u002Fjava\u002Fio\u002Fbyte-stream","Java IO - 字节流","字节流是 Java IO 中最基本的流类型，以字节（byte）为单位进行数据读写，可以处理任意类型的文件。",{"path":429,"title":430,"description":431},"\u002Fother\u002Fjava\u002Fio\u002Fchar-stream","Java IO - 字符流","字符流以字符为单位进行读写，专门用于处理文本文件。相比字节流，字符流能够正确处理字符编码，避免中文乱码问题。",{"path":433,"title":434,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Ffile","Java IO - File 类",{"path":436,"title":437,"description":11},"\u002Fother\u002Fjava\u002Fio\u002Fio-stream-system","Java IO - IO流概述",{"path":439,"title":440,"description":441},"\u002Fother\u002Fjava\u002Fio\u002Fnio","Java IO - NIO","NIO（New IO）是 JDK 1.4 引入的新 IO 模型，提供了更高效的 IO 操作方式，支持非阻塞 IO 和多路复用。",{"path":443,"title":444,"description":445},"\u002Fother\u002Fjava\u002Fjvm\u002Fclass-loading","类加载机制","类加载机制是 JVM 将 .class 文件加载到内存，并对数据进行校验、转换解析和初始化，最终形成可被 JVM 直接使用的 Java 类型的过程。",{"path":447,"title":448,"description":449},"\u002Fother\u002Fjava\u002Fjvm\u002Fgarbage-collection","垃圾回收","垃圾回收（Garbage Collection，GC）是 JVM 自动管理内存的机制，负责回收不再使用的对象所占用的内存。",{"path":451,"title":452,"description":453},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-memory","JVM 内存结构","JVM 在执行 Java 程序时，会把它管理的内存划分为若干个不同的数据区域。这些区域有各自的用途、创建和销毁时间。",{"path":455,"title":456,"description":457},"\u002Fother\u002Fjava\u002Fjvm\u002Fjvm-tuning","JVM 调优","JVM 调优是优化 Java 应用性能的重要手段，主要包括参数配置、性能监控和问题排查。",{"path":459,"title":460,"description":461},"\u002Fother\u002Fjava\u002Fthread\u002Fatomic","原子类","Java 原子类（Atomic Classes）提供了一种无锁的线程安全方式，基于 CAS（Compare-And-Swap）操作实现。",{"path":463,"title":464,"description":465},"\u002Fother\u002Fjava\u002Fthread\u002Fcompletable-future","CompletableFuture","CompletableFuture 是 JDK 8 引入的异步编程工具，实现了 Future 和 CompletionStage 接口，支持函数式编程和链式调用。",{"path":467,"title":468,"description":469},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-collections","并发集合","Java 并发包提供了多种线程安全的集合类，用于替代传统的同步集合（如 Collections.synchronizedList）。",{"path":471,"title":472,"description":473},"\u002Fother\u002Fjava\u002Fthread\u002Fconcurrent-utils","并发工具类","Java 并发包提供了多种实用的并发工具类，用于控制线程之间的协调与同步。",{"path":475,"title":476,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fsynchronized-lock","同步机制",{"path":478,"title":479,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-basic","线程基础",{"path":481,"title":482,"description":11},"\u002Fother\u002Fjava\u002Fthread\u002Fthread-pool","线程池",{"path":484,"title":485,"description":486},"\u002Fother\u002Fspring-series\u002Fspring\u002Fannotations-beans","Spring - 基于注解管理Bean","从 Java 5 开始，Java 增加了对注解（Annotation）的支持，它是代码中的一种特殊标记，可以在编译、类加载和运行时被读取，执行相应的处理。开发人员可以通过注解在不改变原有代码和逻辑的情况下，在源代码中嵌入补充信息。",{"path":488,"title":489,"description":490},"\u002Fother\u002Fspring-series\u002Fspring\u002Fimplement-ioc","Spring - 原理手写IoC","Spring 框架的 IOC 是基于 Java 反射机制实现的，在学习手写 IoC 之前，你需要具备一定的 Java 反射相关的知识，参考本站内的 Java 教程。",{"path":492,"title":493,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fintroduction-case","Spring - 入门案例",{"path":495,"title":496,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aop","Spring - 面向切面AOP",{"path":498,"title":499,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-aot","Spring - AOT提前编译",{"path":501,"title":502,"description":503},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-data-validation","Spring - 数据校验","在开发中，我们经常遇到参数校验的需求，比如用户注册的时候，要校验用户名不能为空、用户名长度不超过20个字符、手机号是合法的手机号格式等等。如果使用普通方式，我们会把校验的代码和真正的业务处理逻辑耦合在一起，而且如果未来要新增一种校验逻辑也需要在修改多个地方。而spring validation允许通过注解的方式来定义对象校验规则，把校验和业务逻辑分离开，让代码编写更加方便。Spring Validation其实就是对Hibernate Validator进一步的封装，方便在Spring中使用。",{"path":505,"title":506,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-i18n","Spring - 国际化i18n",{"path":508,"title":509,"description":510},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-ioc","Spring - IOC容器","IoC 是 Inversion of Control 的简写，译为“控制反转”，它不是一门技术，而是一种设计思想，是一个重要的面向对象编程法则，能够指导我们如何设计出松耦合、更优良的程序。",{"path":512,"title":513,"description":514},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-junit","Spring - 单元测试JUnit","在之前的测试方法中，几乎都能看到以下的两行代码：",{"path":516,"title":517,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-resources","Spring - 资源操作",{"path":519,"title":520,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-summarize","Spring - Spring概述",{"path":522,"title":523,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fspring-transaction","Spring - 事务",{"path":525,"title":526,"description":11},"\u002Fother\u002Fspring-series\u002Fspring\u002Fxml-beans","Spring - 基于XML管理Bean",{"path":528,"title":529,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-config","SpringBoot - 配置详解",{"path":531,"title":532,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-data","SpringBoot - 数据访问",{"path":534,"title":535,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-quickstart","SpringBoot - 快速入门",{"path":537,"title":538,"description":11},"\u002Fother\u002Fspring-series\u002Fspringboot\u002Fspringboot-web","SpringBoot - Web 开发",{"path":540,"title":541,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-config","SpringCloud - 配置中心",{"path":543,"title":544,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-discovery","SpringCloud - 服务注册与发现",{"path":546,"title":547,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-feign","SpringCloud - 服务调用",{"path":549,"title":550,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-gateway","SpringCloud - 服务网关",{"path":552,"title":553,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-introduction","SpringCloud - 微服务概述",{"path":555,"title":556,"description":11},"\u002Fother\u002Fspring-series\u002Fspringcloud\u002Fspringcloud-sentinel","SpringCloud - 服务保护",{"path":558,"title":559,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-databind","SpringMVC - 数据绑定与转换",{"path":561,"title":562,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-exception","SpringMVC - 异常处理",{"path":564,"title":565,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-interceptor","SpringMVC - 拦截器",{"path":567,"title":568,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-introduction","SpringMVC - 简介与环境搭建",{"path":570,"title":571,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-request","SpringMVC - 请求处理",{"path":573,"title":574,"description":11},"\u002Fother\u002Fspring-series\u002Fspringmvc\u002Fspringmvc-response","SpringMVC - 响应处理",{"path":576,"title":577,"description":578},"\u002Fproject\u002Frocket-leaf\u002Farchitecture","项目架构","Rocket-Leaf 的目录结构、模块划分、数据流向，以及各层之间的依赖关系。",{"path":580,"title":581,"description":582},"\u002Fproject\u002Frocket-leaf\u002Fbackend-layers","后端分层设计","Rocket-Leaf 的 model \u002F rocketmq \u002F service 三层结构，以及服务之间的依赖关系与设计取舍。",{"path":584,"title":585,"description":586},"\u002Fproject\u002Frocket-leaf\u002Fclient-manager","RocketMQ 客户端管理器","AdminClientManager 的多客户端池、默认连接懒加载、自动重连重试的设计与实现。",{"path":588,"title":589,"description":590},"\u002Fproject\u002Frocket-leaf\u002Fencryption","连接信息加密存储","AES-256-GCM + SHA-256 字段级派生密钥的实现，以及如何在不破坏兼容性的前提下为历史明文数据做透明迁移。",{"path":592,"title":593,"description":594},"\u002Fproject\u002Frocket-leaf\u002Ffrontend","前端结构与类型绑定","React + Vite 目录组织、自动生成的 Wails 绑定、api 薄封装与自定义 hooks 的职责划分。",{"path":596,"title":597,"description":598},"\u002Fproject\u002Frocket-leaf","项目简介","Rocket-Leaf 是一款基于 Wails v3 构建的跨平台 RocketMQ 桌面管理客户端，Go 后端 + React 前端。本文档系列拆解它的架构与关键实现。",{"path":600,"title":601,"description":602},"\u002Fproject\u002Frocket-leaf\u002Fwails-v3","Wails v3 入门","Wails v3 的核心概念、Service 绑定机制，以及 Rocket-Leaf 是如何用它把 Go 后端和 React 前端打通的。",{"path":604,"title":605,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-basic","Docker - 入门基础",{"path":607,"title":608,"description":609},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-compose","Docker - Compose","在部署应用时，常常使用到不止一个容器，那么在部署容器的时候就需要一个一个进行部署，这样的部署过程也相对来说比较繁琐复杂，也容易出问题，那么有没有一种更为简单的方法呢？",{"path":611,"title":612,"description":613},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-container-connection","Docker - 容器互联","在上一个章节中我们学习了 Docker 容器的端口映射，可以将 Docker 容器和本地以及网络中的端口进行连接起来。",{"path":615,"title":616,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-dockerfile","Docker - Dockerfile",{"path":618,"title":619,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-helloworld","Docker - HelloWorld",{"path":621,"title":622,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-install","Docker - 安装",{"path":624,"title":625,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-introduce","Docker - 简介",{"path":627,"title":628,"description":11},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-object","Docker - 镜像、容器、仓库",{"path":630,"title":631,"description":632},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-warehouse","Docker - 仓库管理","仓库是集中存放资源的地方，代码仓库是存放代码的，那么Docker 中的仓库就是存放 Docker 镜像的。",{"path":634,"title":635,"description":636},"\u002Ftutorials\u002Fcloud\u002Fdocker\u002Fdocker-web-containers","Docker - WEB应用实例","在之前的章节中，仅对普通容器进行了演示，但在实际中常常使用到 Docker 容器中的 WEB 应用程序。",{"path":638,"title":639,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-config","Kubernetes - ConfigMap 与 Secret",{"path":641,"title":642,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-helm","Kubernetes - Helm 包管理",{"path":644,"title":645,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-install","Kubernetes - 集群安装",{"path":647,"title":648,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-introduction","Kubernetes - 简介与架构",{"path":650,"title":651,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-kubectl","Kubernetes - kubectl 命令行工具",{"path":653,"title":654,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-monitoring","Kubernetes - 监控与日志",{"path":656,"title":657,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-network-security","Kubernetes - 网络与安全",{"path":659,"title":660,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-service","Kubernetes - Service 与 Ingress",{"path":662,"title":663,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-storage","Kubernetes - 持久化存储",{"path":665,"title":666,"description":11},"\u002Ftutorials\u002Fcloud\u002Fkubernetes\u002Fk8s-workload","Kubernetes - 工作负载资源",{"path":668,"title":669,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-bash","Linux - Bash 基础语法",{"path":671,"title":672,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-file-directory","Linux - 文件与目录操作",{"path":674,"title":675,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-network","Linux - 网络配置",{"path":677,"title":678,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-package","Linux - 软件包管理",{"path":680,"title":681,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-process","Linux - 进程管理",{"path":683,"title":684,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-scripts","Linux - 常用脚本示例",{"path":686,"title":687,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-service","Linux - 服务管理",{"path":689,"title":690,"description":11},"\u002Ftutorials\u002Fcloud\u002Flinux\u002Flinux-user-permission","Linux - 用户与权限管理",{"path":692,"title":693,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-https","Nginx - HTTPS 配置",{"path":695,"title":696,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-install","Nginx - 安装与配置",{"path":698,"title":699,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-loadbalance","Nginx - 负载均衡",{"path":701,"title":702,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-optimization","Nginx - 性能优化",{"path":704,"title":705,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-proxy","Nginx - 反向代理",{"path":707,"title":708,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-static","Nginx - 静态资源服务",{"path":710,"title":711,"description":11},"\u002Ftutorials\u002Fcloud\u002Fnginx\u002Fnginx-vhost","Nginx - 虚拟主机配置",{"path":713,"title":714,"description":715},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-architecture","MySQL 高可用架构","主从复制、读写分离、分库分表。",{"path":717,"title":718,"description":719},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-index","MySQL 索引","索引是帮助 MySQL 高效获取数据的有序数据结构。",{"path":721,"title":722,"description":723},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-lock","MySQL 锁","锁用于解决并发访问时的数据一致性问题。",{"path":725,"title":726,"description":727},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-optimize","MySQL 性能优化","SQL 优化是后端开发必备技能。",{"path":729,"title":730,"description":731},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fmysql-transaction","MySQL 事务","事务是一组不可分割的操作，要么全部成功，要么全部失败。",{"path":733,"title":734,"description":735},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-advanced","SQL 进阶","多表查询、子查询、函数、视图、存储过程。",{"path":737,"title":738,"description":739},"\u002Ftutorials\u002Fdatabase\u002Fmysql\u002Fsql-basic","SQL 基础","SQL（Structured Query Language）是操作关系型数据库的标准语言。",{"path":741,"title":742,"description":743},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-advanced","Redis 进阶功能","事务、发布订阅、Lua 脚本、Pipeline。",{"path":745,"title":746,"description":747},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-basic","Redis 基础","Redis 安装配置与基本命令。",{"path":749,"title":750,"description":751},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-cluster","Redis 高可用","主从复制、哨兵、Cluster 集群。",{"path":753,"title":754,"description":755},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-datatype","Redis 数据类型","Redis 5 种基本数据类型 + 4 种特殊类型。",{"path":757,"title":758,"description":759},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-optimize","Redis 性能优化","内存优化、缓存问题、最佳实践。",{"path":761,"title":762,"description":763},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-persistence","Redis 持久化","Redis 提供 RDB 和 AOF 两种持久化方式。",{"path":765,"title":766,"description":767},"\u002Ftutorials\u002Fdatabase\u002Fredis\u002Fredis-principle","Redis 底层原理","数据结构、线程模型、网络模型。",{"path":769,"title":770,"description":771},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fbehaiver-patterns\u002Fobserver-pattern","观察者模式","观察者模式属于行为型模式，定义了对象之间的一对多的依赖关系，在这种模式中，当一个对象的状态发生变化时，所有依赖于它的对象都会得到通知，并且执行相关操作。观察者模式又被成为“发布—订阅模式”，即发布者发生改变后，会通知所有订阅者。",{"path":773,"title":774,"description":11},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Ffactory-pattern","工厂模式",{"path":776,"title":777,"description":778},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fcreate-patterns\u002Fsingleton-pattern","单例模式","单例模式是最常用的设计模式之一，他可以保证在整个应用中，某个类只存在一个实例化对象，即全局使用到该类的只有一个对象，这种模式在需要限制某些类的实例数量时非常有用，通常全局只需要一个该对象即可，如一些配置文件映射对象、数据库连接对象等。",{"path":780,"title":781,"description":782},"\u002Ftutorials\u002Fdev-idea\u002Fdesign-patterns\u002Fstructural-patterns\u002Fadapter-pattern","适配器模式","适配器模式是一种结构型模式，可以将一个类的接口转换成客户端所期望的另一种接口，适配器模式可以帮助开发人员在不修改现有代码的情况下，将不兼容的类组合在一起。",{"path":784,"title":785,"description":786},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-basic-operations","Git 创建版本库","在 Git 上创建版本库有两种方式，一种是直接拷贝远程 Git 仓库到本地，另外一种是我们自己创建本地的版本库。",{"path":788,"title":789,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-branch-manage","Git 分支管理",{"path":791,"title":792,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-content-operations","Git 仓库内容操作",{"path":794,"title":795,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-introduce-install","Git 介绍和安装",{"path":797,"title":798,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-remote-manage","Git 远程管理",{"path":800,"title":801,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fgit\u002Fgit-workspace-index-repo","Git 工作原理",{"path":803,"title":804,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fhomebrew","HomeBrew 教程",{"path":806,"title":807,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fidea\u002Fshortcuts","快捷键",{"path":809,"title":810,"description":11},"\u002Ftutorials\u002Fdev-tools\u002Fmaven\u002Fintroduce-install-config","Maven - 介绍、安装、配置",{"path":812,"title":813,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fbasic-knowledge","2. 基础知识",{"path":815,"title":816,"description":817},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomponent-communication","9. 组件通信","在前面的章节内，介绍了 Vue 中最核心的内容——组件的介绍和使用，和 Java 等编程语言相反，组件并不近似于这些变成语言中的类，类可以通过类或者其实例化的对象来相互交互，但 Vue 组件之间的作用域是相互独立的，这就意味着不同组件之间的数据无法相互引用。",{"path":819,"title":820,"description":821},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcomputed","4. 计算属性","虽然直接在模板中使用表达式方便，但是如果在模板中添加很多逻辑，会让模板变的臃肿且难维护，耦合度较高。有没有一种简单的方式来实现呢？答案是有的。",{"path":823,"title":824,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fcreate-vue-project","1. 环境搭建及安装",{"path":826,"title":827,"description":828},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Flife-cycle","6. 生命周期","生命周期是指组件从创建、挂载、更新到销毁的整个过程中所经历的一系列阶段。在 Vue 中，每个组件都有自己的生命周期，可以通过生命周期钩子函数来监听和处理组件在不同阶段的行为和状态。",{"path":830,"title":831,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fother-api","10. 其他 API",{"path":833,"title":834,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fpinia","8. Pinia",{"path":836,"title":837,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter","7. 路由",{"path":839,"title":840,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","3. 指令及模板语法",{"path":842,"title":843,"description":11},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fvue3-new-component","11. Vue3 新组件",{"path":845,"title":846,"description":847},"\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Fwatch","5. 监视","Watch 是 Vue 提供的一个用于监视响应式数据变化并执行相应操作的 API，能够对响应式数据的变化做出一些操作的功能。Vue3 中的 Watch 支持多种用法，包括监视响应式对象、ref 对象、数组、函数等。",{"path":849,"title":850,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-introduction","Kafka 简介与安装",{"path":852,"title":853,"description":11},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-producer-consumer","Kafka 生产者与消费者",{"path":855,"title":856,"description":857},"\u002Ftutorials\u002Fmq\u002Fkafka\u002Fkafka-springboot","Spring Boot 整合 Kafka","Spring Kafka 提供了对 Apache Kafka 的便捷集成。",{"path":859,"title":860,"description":861},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-exchange","RabbitMQ Exchange 详解","Exchange（交换机）是 RabbitMQ 的核心组件，负责接收生产者发送的消息，并根据规则将消息路由到一个或多个队列。",{"path":863,"title":864,"description":11},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-introduction","RabbitMQ 简介与安装",{"path":866,"title":867,"description":868},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-reliability","RabbitMQ 消息可靠性","消息可靠性是消息队列的核心要求，RabbitMQ 提供了多种机制来保证消息不丢失。",{"path":870,"title":871,"description":872},"\u002Ftutorials\u002Fmq\u002Frabbitmq\u002Frabbitmq-springboot","Spring Boot 整合 RabbitMQ","Spring AMQP 提供了对 RabbitMQ 的便捷集成，大大简化了开发工作。",{"path":874,"title":875,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-client","RocketMQ 客户端使用",{"path":877,"title":878,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-concepts","RocketMQ 核心概念",{"path":880,"title":881,"description":11},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-installation","RocketMQ 安装部署",{"path":883,"title":884,"description":885},"\u002Ftutorials\u002Fmq\u002Frocketmq\u002Frocketmq-message-type","RocketMQ 消息类型","RocketMQ 支持多种消息类型，满足不同业务场景需求。",{"id":887,"title":837,"body":888,"description":11,"extension":3559,"meta":3560,"navigation":1013,"path":836,"seo":3561,"stem":3562,"__hash__":3563},"docs\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Frouter.md",{"type":889,"value":890,"toc":3536},"minimark",[891,895,899,902,907,910,913,976,979,985,1292,1295,1311,1314,1317,1322,1327,1477,1482,1528,1532,1536,1664,1668,1709,3533],[892,893,894],"h2",{"id":894},"概念",[896,897,898],"p",{},"在 Web 开发中，路由是指根据用户的请求路径来决定显示哪个页面或者组件的过程。你也可以将路由理解为 url 和 页面或组件 的一个映射关系，访问 url，就展示对应页面。在 Vue 中这个过程通过 vue-router 来实现的。",[896,900,901],{},"由于 Vue 在开发时对路由支持的不足，于是官方补充了 vue-router 插件，通过 vue-router 可以实现多视图的单页 Web 应用（single page web application，SPA）。",[903,904,906],"warning",{"title":905},"为什么不使用 a 标签来进行页面的跳转呢？","\n因为我们的 Vue 项目大都是单页面应用，只有一个 index.html 主页，凡是你看到的页面，都是挂载到该页面上的组件，所以无法使用传统的 a 标签来直接进行页面的跳转，需要使用 Vue 提供的 vue-router 路由来进行管理。\n",[892,908,909],{"id":909},"安装",[896,911,912],{},"Vue 默认是没有安装 vue-router 路由插件的，在正式使用之前，请先安装路由。在你项目的根目录下执行如下指令，即可安装 vue-router 插件。",[914,915,916,917,942,945,959,962],"note",{},"\n@tab npm\n",[918,919,923],"pre",{"className":920,"code":921,"language":922,"meta":11,"style":11},"language-bash shiki shiki-themes github-light github-light github-dark","npm install vue-router\n","bash",[924,925,926],"code",{"__ignoreMap":11},[927,928,931,935,939],"span",{"class":929,"line":930},"line",1,[927,932,934],{"class":933},"snPdu","npm",[927,936,938],{"class":937},"sIIMD"," install",[927,940,941],{"class":937}," vue-router\n",[896,943,944],{},"@tab yarn",[918,946,948],{"className":920,"code":947,"language":922,"meta":11,"style":11},"yarn install vue-router\n",[924,949,950],{"__ignoreMap":11},[927,951,952,955,957],{"class":929,"line":930},[927,953,954],{"class":933},"yarn",[927,956,938],{"class":937},[927,958,941],{"class":937},[896,960,961],{},"@tab cnpm",[918,963,965],{"className":920,"code":964,"language":922,"meta":11,"style":11},"cnpm install vue-router\n",[924,966,967],{"__ignoreMap":11},[927,968,969,972,974],{"class":929,"line":930},[927,970,971],{"class":933},"cnpm",[927,973,938],{"class":937},[927,975,941],{"class":937},[892,977,978],{"id":978},"路由定义",[896,980,981,982],{},"使用路由之前，需要先进行路由的配置，主要配置 URL 和 页面组件的映射关系。创建路由配置文件 ",[924,983,984],{},"\u002Fsrc\u002Frouter\u002Findex.js",[918,986,990],{"className":987,"code":988,"language":989,"meta":11,"style":11},"language-ts shiki shiki-themes github-light github-light github-dark","import { createRouter,createWebHistory } from 'vue-router'\n\nimport Home from '..\u002Fpages\u002FHome.vue'\nimport News from '..\u002Fpages\u002FNews.vue'\nimport Detail from '..\u002Fpages\u002FDetail.vue'\n\n\u002F\u002F 构建路由映射对象\nconst routes = [\n    {\n        path: '\u002F',\n        name: 'home',\n        component: Home\n    },\n    {\n        path: '\u002Fnews',\n        name: 'news',\n        component: News,\n        children:[\n                {\n                    path: '\u002Fdetail',\n                    name: 'detail',\n                    component: Detail\n                }\n            ]\n    }\n];\n\n\u002F\u002F 创建路由对象\nconst router = createRouter({\n    \u002F\u002F 配置路由器模式\n    history: createWebHistory(),\n    routes\n});\n\nexport default router\n","ts",[924,991,992,1008,1015,1028,1041,1054,1059,1066,1082,1088,1100,1111,1117,1123,1128,1138,1148,1154,1160,1166,1177,1188,1194,1200,1206,1212,1218,1223,1229,1245,1251,1263,1269,1275,1280],{"__ignoreMap":11},[927,993,994,998,1002,1005],{"class":929,"line":930},[927,995,997],{"class":996},"s8jYJ","import",[927,999,1001],{"class":1000},"sxrX7"," { createRouter,createWebHistory } ",[927,1003,1004],{"class":996},"from",[927,1006,1007],{"class":937}," 'vue-router'\n",[927,1009,1011],{"class":929,"line":1010},2,[927,1012,1014],{"emptyLinePlaceholder":1013},true,"\n",[927,1016,1018,1020,1023,1025],{"class":929,"line":1017},3,[927,1019,997],{"class":996},[927,1021,1022],{"class":1000}," Home ",[927,1024,1004],{"class":996},[927,1026,1027],{"class":937}," '..\u002Fpages\u002FHome.vue'\n",[927,1029,1031,1033,1036,1038],{"class":929,"line":1030},4,[927,1032,997],{"class":996},[927,1034,1035],{"class":1000}," News ",[927,1037,1004],{"class":996},[927,1039,1040],{"class":937}," '..\u002Fpages\u002FNews.vue'\n",[927,1042,1044,1046,1049,1051],{"class":929,"line":1043},5,[927,1045,997],{"class":996},[927,1047,1048],{"class":1000}," Detail ",[927,1050,1004],{"class":996},[927,1052,1053],{"class":937}," '..\u002Fpages\u002FDetail.vue'\n",[927,1055,1057],{"class":929,"line":1056},6,[927,1058,1014],{"emptyLinePlaceholder":1013},[927,1060,1062],{"class":929,"line":1061},7,[927,1063,1065],{"class":1064},"sCsY4","\u002F\u002F 构建路由映射对象\n",[927,1067,1069,1072,1076,1079],{"class":929,"line":1068},8,[927,1070,1071],{"class":996},"const",[927,1073,1075],{"class":1074},"sBjJW"," routes",[927,1077,1078],{"class":996}," =",[927,1080,1081],{"class":1000}," [\n",[927,1083,1085],{"class":929,"line":1084},9,[927,1086,1087],{"class":1000},"    {\n",[927,1089,1091,1094,1097],{"class":929,"line":1090},10,[927,1092,1093],{"class":1000},"        path: ",[927,1095,1096],{"class":937},"'\u002F'",[927,1098,1099],{"class":1000},",\n",[927,1101,1103,1106,1109],{"class":929,"line":1102},11,[927,1104,1105],{"class":1000},"        name: ",[927,1107,1108],{"class":937},"'home'",[927,1110,1099],{"class":1000},[927,1112,1114],{"class":929,"line":1113},12,[927,1115,1116],{"class":1000},"        component: Home\n",[927,1118,1120],{"class":929,"line":1119},13,[927,1121,1122],{"class":1000},"    },\n",[927,1124,1126],{"class":929,"line":1125},14,[927,1127,1087],{"class":1000},[927,1129,1131,1133,1136],{"class":929,"line":1130},15,[927,1132,1093],{"class":1000},[927,1134,1135],{"class":937},"'\u002Fnews'",[927,1137,1099],{"class":1000},[927,1139,1141,1143,1146],{"class":929,"line":1140},16,[927,1142,1105],{"class":1000},[927,1144,1145],{"class":937},"'news'",[927,1147,1099],{"class":1000},[927,1149,1151],{"class":929,"line":1150},17,[927,1152,1153],{"class":1000},"        component: News,\n",[927,1155,1157],{"class":929,"line":1156},18,[927,1158,1159],{"class":1000},"        children:[\n",[927,1161,1163],{"class":929,"line":1162},19,[927,1164,1165],{"class":1000},"                {\n",[927,1167,1169,1172,1175],{"class":929,"line":1168},20,[927,1170,1171],{"class":1000},"                    path: ",[927,1173,1174],{"class":937},"'\u002Fdetail'",[927,1176,1099],{"class":1000},[927,1178,1180,1183,1186],{"class":929,"line":1179},21,[927,1181,1182],{"class":1000},"                    name: ",[927,1184,1185],{"class":937},"'detail'",[927,1187,1099],{"class":1000},[927,1189,1191],{"class":929,"line":1190},22,[927,1192,1193],{"class":1000},"                    component: Detail\n",[927,1195,1197],{"class":929,"line":1196},23,[927,1198,1199],{"class":1000},"                }\n",[927,1201,1203],{"class":929,"line":1202},24,[927,1204,1205],{"class":1000},"            ]\n",[927,1207,1209],{"class":929,"line":1208},25,[927,1210,1211],{"class":1000},"    }\n",[927,1213,1215],{"class":929,"line":1214},26,[927,1216,1217],{"class":1000},"];\n",[927,1219,1221],{"class":929,"line":1220},27,[927,1222,1014],{"emptyLinePlaceholder":1013},[927,1224,1226],{"class":929,"line":1225},28,[927,1227,1228],{"class":1064},"\u002F\u002F 创建路由对象\n",[927,1230,1232,1234,1237,1239,1242],{"class":929,"line":1231},29,[927,1233,1071],{"class":996},[927,1235,1236],{"class":1074}," router",[927,1238,1078],{"class":996},[927,1240,1241],{"class":933}," createRouter",[927,1243,1244],{"class":1000},"({\n",[927,1246,1248],{"class":929,"line":1247},30,[927,1249,1250],{"class":1064},"    \u002F\u002F 配置路由器模式\n",[927,1252,1254,1257,1260],{"class":929,"line":1253},31,[927,1255,1256],{"class":1000},"    history: ",[927,1258,1259],{"class":933},"createWebHistory",[927,1261,1262],{"class":1000},"(),\n",[927,1264,1266],{"class":929,"line":1265},32,[927,1267,1268],{"class":1000},"    routes\n",[927,1270,1272],{"class":929,"line":1271},33,[927,1273,1274],{"class":1000},"});\n",[927,1276,1278],{"class":929,"line":1277},34,[927,1279,1014],{"emptyLinePlaceholder":1013},[927,1281,1283,1286,1289],{"class":929,"line":1282},35,[927,1284,1285],{"class":996},"export",[927,1287,1288],{"class":996}," default",[927,1290,1291],{"class":1000}," router\n",[896,1293,1294],{},"其中routes 是一个数组，其中的元素就是路由映射信息。",[1296,1297,1298,1302,1305,1308],"ul",{},[1299,1300,1301],"li",{},"path：对应的 URL 信息",[1299,1303,1304],{},"name：路由名称",[1299,1306,1307],{},"component：组件信息",[1299,1309,1310],{},"children：子路由信息",[914,1312],{"title":1313},"路由的映射关系中，也支持配置子路由，便于 URL 匹配，支持多级子路由嵌套",[892,1315,1316],{"id":1316},"路由传参",[1318,1319,1321],"h3",{"id":1320},"query-参数","Query 参数",[1296,1323,1324],{},[1299,1325,1326],{},"传递参数",[918,1328,1332],{"className":1329,"code":1330,"language":1331,"meta":11,"style":11},"language-vue shiki shiki-themes github-light github-light github-dark","\u003C!-- 跳转并携带query参数（to的字符串写法） -->\n\u003Crouter-link to=\"\u002Fnews\u002Fdetail?a=1&b=2&content=欢迎你\">\n    跳转\n\u003C\u002Frouter-link>\n                \n\u003C!-- 跳转并携带query参数（to的对象写法） -->\n\u003CRouterLink \n  :to=\"{\n    \u002F\u002Fname:'xiang', \u002F\u002F用name也可以跳转\n    path:'\u002Fnews\u002Fdetail',\n    query:{\n      id:news.id,\n      title:news.title,\n      content:news.content\n    }\n  }\"\n>\n  {{news.title}}\n\u003C\u002FRouterLink>\n","vue",[924,1333,1334,1339,1360,1365,1374,1379,1384,1394,1410,1418,1428,1433,1438,1443,1448,1452,1460,1464,1469],{"__ignoreMap":11},[927,1335,1336],{"class":929,"line":930},[927,1337,1338],{"class":1064},"\u003C!-- 跳转并携带query参数（to的字符串写法） -->\n",[927,1340,1341,1344,1348,1351,1354,1357],{"class":929,"line":1010},[927,1342,1343],{"class":1000},"\u003C",[927,1345,1347],{"class":1346},"sovSZ","router-link",[927,1349,1350],{"class":933}," to",[927,1352,1353],{"class":1000},"=",[927,1355,1356],{"class":937},"\"\u002Fnews\u002Fdetail?a=1&b=2&content=欢迎你\"",[927,1358,1359],{"class":1000},">\n",[927,1361,1362],{"class":929,"line":1017},[927,1363,1364],{"class":1000},"    跳转\n",[927,1366,1367,1370,1372],{"class":929,"line":1030},[927,1368,1369],{"class":1000},"\u003C\u002F",[927,1371,1347],{"class":1346},[927,1373,1359],{"class":1000},[927,1375,1376],{"class":929,"line":1043},[927,1377,1378],{"class":1000},"                \n",[927,1380,1381],{"class":929,"line":1056},[927,1382,1383],{"class":1064},"\u003C!-- 跳转并携带query参数（to的对象写法） -->\n",[927,1385,1386,1388,1391],{"class":929,"line":1061},[927,1387,1343],{"class":1000},[927,1389,1390],{"class":1346},"RouterLink",[927,1392,1393],{"class":1000}," \n",[927,1395,1396,1399,1402,1404,1407],{"class":929,"line":1068},[927,1397,1398],{"class":1000},"  :",[927,1400,1401],{"class":933},"to",[927,1403,1353],{"class":1000},[927,1405,1406],{"class":937},"\"",[927,1408,1409],{"class":1000},"{\n",[927,1411,1412,1415],{"class":929,"line":1084},[927,1413,1414],{"class":1064},"    \u002F\u002Fname:'xiang',",[927,1416,1417],{"class":1064}," \u002F\u002F用name也可以跳转\n",[927,1419,1420,1423,1426],{"class":929,"line":1090},[927,1421,1422],{"class":1000},"    path:",[927,1424,1425],{"class":937},"'\u002Fnews\u002Fdetail'",[927,1427,1099],{"class":1000},[927,1429,1430],{"class":929,"line":1102},[927,1431,1432],{"class":1000},"    query:{\n",[927,1434,1435],{"class":929,"line":1113},[927,1436,1437],{"class":1000},"      id:news.id,\n",[927,1439,1440],{"class":929,"line":1119},[927,1441,1442],{"class":1000},"      title:news.title,\n",[927,1444,1445],{"class":929,"line":1125},[927,1446,1447],{"class":1000},"      content:news.content\n",[927,1449,1450],{"class":929,"line":1130},[927,1451,1211],{"class":1000},[927,1453,1454,1457],{"class":929,"line":1140},[927,1455,1456],{"class":1000},"  }",[927,1458,1459],{"class":937},"\"\n",[927,1461,1462],{"class":929,"line":1150},[927,1463,1359],{"class":1000},[927,1465,1466],{"class":929,"line":1156},[927,1467,1468],{"class":1000},"  {{news.title}}\n",[927,1470,1471,1473,1475],{"class":929,"line":1162},[927,1472,1369],{"class":1000},[927,1474,1390],{"class":1346},[927,1476,1359],{"class":1000},[1296,1478,1479],{},[1299,1480,1481],{},"接收参数",[918,1483,1485],{"className":987,"code":1484,"language":989,"meta":11,"style":11},"import {useRoute} from 'vue-router'\nconst route = useRoute()\n\u002F\u002F 打印query参数\nconsole.log(route.query)\n",[924,1486,1487,1498,1513,1518],{"__ignoreMap":11},[927,1488,1489,1491,1494,1496],{"class":929,"line":930},[927,1490,997],{"class":996},[927,1492,1493],{"class":1000}," {useRoute} ",[927,1495,1004],{"class":996},[927,1497,1007],{"class":937},[927,1499,1500,1502,1505,1507,1510],{"class":929,"line":1010},[927,1501,1071],{"class":996},[927,1503,1504],{"class":1074}," route",[927,1506,1078],{"class":996},[927,1508,1509],{"class":933}," useRoute",[927,1511,1512],{"class":1000},"()\n",[927,1514,1515],{"class":929,"line":1017},[927,1516,1517],{"class":1064},"\u002F\u002F 打印query参数\n",[927,1519,1520,1523,1525],{"class":929,"line":1030},[927,1521,1522],{"class":1000},"console.",[927,1524,260],{"class":933},[927,1526,1527],{"class":1000},"(route.query)\n",[1318,1529,1531],{"id":1530},"params-参数","Params 参数",[1296,1533,1534],{},[1299,1535,1326],{},[918,1537,1539],{"className":1329,"code":1538,"language":1331,"meta":11,"style":11},"\u003C!-- 跳转并携带params参数（to的字符串写法） -->\n\u003CRouterLink :to=\"`\u002Fnews\u002Fdetail\u002F001\u002F新闻001\u002F内容001`\">{{news.title}}\u003C\u002FRouterLink>\n\n\u003C!-- 跳转并携带params参数（to的对象写法） -->\n\u003CRouterLink \n    :to=\"{\n      name:'xiang', \u002F\u002F用name跳转\n      params:{\n        id:news.id,\n        title:news.title,\n        content:news.title\n      }\n    }\"\n  >\n    {{news.title}}\n  \u003C\u002FRouterLink>\n",[924,1540,1541,1546,1569,1573,1578,1586,1599,1613,1618,1623,1628,1633,1638,1645,1650,1655],{"__ignoreMap":11},[927,1542,1543],{"class":929,"line":930},[927,1544,1545],{"class":1064},"\u003C!-- 跳转并携带params参数（to的字符串写法） -->\n",[927,1547,1548,1550,1552,1555,1557,1559,1562,1565,1567],{"class":929,"line":1010},[927,1549,1343],{"class":1000},[927,1551,1390],{"class":1346},[927,1553,1554],{"class":1000}," :",[927,1556,1401],{"class":933},[927,1558,1353],{"class":1000},[927,1560,1561],{"class":937},"\"`\u002Fnews\u002Fdetail\u002F001\u002F新闻001\u002F内容001`\"",[927,1563,1564],{"class":1000},">{{news.title}}\u003C\u002F",[927,1566,1390],{"class":1346},[927,1568,1359],{"class":1000},[927,1570,1571],{"class":929,"line":1017},[927,1572,1014],{"emptyLinePlaceholder":1013},[927,1574,1575],{"class":929,"line":1030},[927,1576,1577],{"class":1064},"\u003C!-- 跳转并携带params参数（to的对象写法） -->\n",[927,1579,1580,1582,1584],{"class":929,"line":1043},[927,1581,1343],{"class":1000},[927,1583,1390],{"class":1346},[927,1585,1393],{"class":1000},[927,1587,1588,1591,1593,1595,1597],{"class":929,"line":1056},[927,1589,1590],{"class":1000},"    :",[927,1592,1401],{"class":933},[927,1594,1353],{"class":1000},[927,1596,1406],{"class":937},[927,1598,1409],{"class":1000},[927,1600,1601,1604,1607,1610],{"class":929,"line":1061},[927,1602,1603],{"class":1000},"      name:",[927,1605,1606],{"class":937},"'xiang'",[927,1608,1609],{"class":1000},", ",[927,1611,1612],{"class":1064},"\u002F\u002F用name跳转\n",[927,1614,1615],{"class":929,"line":1068},[927,1616,1617],{"class":1000},"      params:{\n",[927,1619,1620],{"class":929,"line":1084},[927,1621,1622],{"class":1000},"        id:news.id,\n",[927,1624,1625],{"class":929,"line":1090},[927,1626,1627],{"class":1000},"        title:news.title,\n",[927,1629,1630],{"class":929,"line":1102},[927,1631,1632],{"class":1000},"        content:news.title\n",[927,1634,1635],{"class":929,"line":1113},[927,1636,1637],{"class":1000},"      }\n",[927,1639,1640,1643],{"class":929,"line":1119},[927,1641,1642],{"class":1000},"    }",[927,1644,1459],{"class":937},[927,1646,1647],{"class":929,"line":1125},[927,1648,1649],{"class":1000},"  >\n",[927,1651,1652],{"class":929,"line":1130},[927,1653,1654],{"class":1000},"    {{news.title}}\n",[927,1656,1657,1660,1662],{"class":929,"line":1140},[927,1658,1659],{"class":1000},"  \u003C\u002F",[927,1661,1390],{"class":1346},[927,1663,1359],{"class":1000},[1296,1665,1666],{},[1299,1667,1481],{},[918,1669,1671],{"className":987,"code":1670,"language":989,"meta":11,"style":11},"import {useRoute} from 'vue-router'\nconst route = useRoute()\n\u002F\u002F 打印params参数\nconsole.log(route.params)\n",[924,1672,1673,1683,1695,1700],{"__ignoreMap":11},[927,1674,1675,1677,1679,1681],{"class":929,"line":930},[927,1676,997],{"class":996},[927,1678,1493],{"class":1000},[927,1680,1004],{"class":996},[927,1682,1007],{"class":937},[927,1684,1685,1687,1689,1691,1693],{"class":929,"line":1010},[927,1686,1071],{"class":996},[927,1688,1504],{"class":1074},[927,1690,1078],{"class":996},[927,1692,1509],{"class":933},[927,1694,1512],{"class":1000},[927,1696,1697],{"class":929,"line":1017},[927,1698,1699],{"class":1064},"\u002F\u002F 打印params参数\n",[927,1701,1702,1704,1706],{"class":929,"line":1030},[927,1703,1522],{"class":1000},[927,1705,260],{"class":933},[927,1707,1708],{"class":1000},"(route.params)\n",[903,1710,1712,1713,1722,1725,1731,1735,1738,1741,1955,1958,1962,1965,2004,2008,2011,2048,2052,2062,2112,2116,2119,2193,2196,2200,2203,2233,2237,2240,2288,2291,2295,2298,2316,2323,2326,2329,2332,2338,2377,2385,2390,2424,2432,2435,2449,2454,2489,2494,2528,2533,2641,2644,2647,2650,2669,2672,2675,2905,2908,2911,2914,2921,3091,3096,3186,3191,3516],{"title":1711},"注意","\n- 传递`params`参数时，若使用`to`的对象写法，必须使用`name`配置项，不能用`path`。\n",[1296,1714,1715],{},[1299,1716,1717,1718,1721],{},"传递",[924,1719,1720],{},"params","参数时，需要提前在规则中占位。\n\n",[892,1723,1390],{"id":1724},"routerlink",[896,1726,1727,1730],{},[924,1728,1729],{},"\u003Crouter-link>"," 是一个组件，该组件用于设置一个导航链接，切换不同的 HTML 内容。使得 Vue Router 可以在不重新加载页面的情况下更改 URL，处理 URL 的生成以及编码。",[1318,1732,1734],{"id":1733},"to-属性","To 属性",[896,1736,1737],{},"to 属性值表示目标路由的链接。当被点击后，内部会立刻把 to 的值传到 router.push()，所以这个值可以是一个字符串或者是描述目标位置的对象。",[896,1739,1740],{},"to 属性有两种写法，一种是静态的 url 写法，另外一种是 v-bind 绑定的对象写法，对象可以传入路由的名称或者路径，在使用之前需要在 \u003CBadge text=\"\u002Fsrc\u002Frouter\u002Findex.ts\" vertical=\"middle\" type=\"note\"\u002F> 中进行注册声明，也只有声明过的路由才能进行跳转。",[918,1742,1744],{"className":1329,"code":1743,"language":1331,"meta":11,"style":11},"\u003C!-- 第一种：to的字符串写法 -->\n\u003Crouter-link active-class=\"active\" to=\"\u002Fhome\">主页\u003C\u002Frouter-link>\n\n\u003C!-- 第二种：to的对象写法 -->\n\u003Crouter-link active-class=\"active\" :to=\"{ path : '\u002Fhome' }\">Home\u003C\u002Frouter-link>\n\u003Crouter-link active-class=\"active\" :to=\"{ name : 'news' }\">新闻\u003C\u002Frouter-link>\n\n\u003C!-- 命名的路由 -->\n\u003Crouter-link :to=\"{ name: 'user', params: { userId: 123 }}\">User\u003C\u002Frouter-link>\n\n\u003C!-- 带查询参数，下面的结果为 \u002Fregister?plan=private -->\n\u003Crouter-link :to=\"{ path: 'register', query: { plan: 'private' }}\">Register\u003C\u002Frouter-link>\n",[924,1745,1746,1751,1779,1783,1788,1826,1862,1866,1871,1909,1913,1918],{"__ignoreMap":11},[927,1747,1748],{"class":929,"line":930},[927,1749,1750],{"class":1064},"\u003C!-- 第一种：to的字符串写法 -->\n",[927,1752,1753,1755,1757,1760,1762,1765,1767,1769,1772,1775,1777],{"class":929,"line":1010},[927,1754,1343],{"class":1000},[927,1756,1347],{"class":1346},[927,1758,1759],{"class":933}," active-class",[927,1761,1353],{"class":1000},[927,1763,1764],{"class":937},"\"active\"",[927,1766,1350],{"class":933},[927,1768,1353],{"class":1000},[927,1770,1771],{"class":937},"\"\u002Fhome\"",[927,1773,1774],{"class":1000},">主页\u003C\u002F",[927,1776,1347],{"class":1346},[927,1778,1359],{"class":1000},[927,1780,1781],{"class":929,"line":1017},[927,1782,1014],{"emptyLinePlaceholder":1013},[927,1784,1785],{"class":929,"line":1030},[927,1786,1787],{"class":1064},"\u003C!-- 第二种：to的对象写法 -->\n",[927,1789,1790,1792,1794,1796,1798,1800,1802,1804,1806,1808,1811,1814,1817,1819,1822,1824],{"class":929,"line":1043},[927,1791,1343],{"class":1000},[927,1793,1347],{"class":1346},[927,1795,1759],{"class":933},[927,1797,1353],{"class":1000},[927,1799,1764],{"class":937},[927,1801,1554],{"class":1000},[927,1803,1401],{"class":933},[927,1805,1353],{"class":1000},[927,1807,1406],{"class":937},[927,1809,1810],{"class":1000},"{ path : ",[927,1812,1813],{"class":937},"'\u002Fhome'",[927,1815,1816],{"class":1000}," }",[927,1818,1406],{"class":937},[927,1820,1821],{"class":1000},">Home\u003C\u002F",[927,1823,1347],{"class":1346},[927,1825,1359],{"class":1000},[927,1827,1828,1830,1832,1834,1836,1838,1840,1842,1844,1846,1849,1851,1853,1855,1858,1860],{"class":929,"line":1056},[927,1829,1343],{"class":1000},[927,1831,1347],{"class":1346},[927,1833,1759],{"class":933},[927,1835,1353],{"class":1000},[927,1837,1764],{"class":937},[927,1839,1554],{"class":1000},[927,1841,1401],{"class":933},[927,1843,1353],{"class":1000},[927,1845,1406],{"class":937},[927,1847,1848],{"class":1000},"{ name : ",[927,1850,1145],{"class":937},[927,1852,1816],{"class":1000},[927,1854,1406],{"class":937},[927,1856,1857],{"class":1000},">新闻\u003C\u002F",[927,1859,1347],{"class":1346},[927,1861,1359],{"class":1000},[927,1863,1864],{"class":929,"line":1061},[927,1865,1014],{"emptyLinePlaceholder":1013},[927,1867,1868],{"class":929,"line":1068},[927,1869,1870],{"class":1064},"\u003C!-- 命名的路由 -->\n",[927,1872,1873,1875,1877,1879,1881,1883,1885,1888,1891,1894,1897,1900,1902,1905,1907],{"class":929,"line":1084},[927,1874,1343],{"class":1000},[927,1876,1347],{"class":1346},[927,1878,1554],{"class":1000},[927,1880,1401],{"class":933},[927,1882,1353],{"class":1000},[927,1884,1406],{"class":937},[927,1886,1887],{"class":1000},"{ name: ",[927,1889,1890],{"class":937},"'user'",[927,1892,1893],{"class":1000},", params: { userId: ",[927,1895,1896],{"class":1074},"123",[927,1898,1899],{"class":1000}," }}",[927,1901,1406],{"class":937},[927,1903,1904],{"class":1000},">User\u003C\u002F",[927,1906,1347],{"class":1346},[927,1908,1359],{"class":1000},[927,1910,1911],{"class":929,"line":1090},[927,1912,1014],{"emptyLinePlaceholder":1013},[927,1914,1915],{"class":929,"line":1102},[927,1916,1917],{"class":1064},"\u003C!-- 带查询参数，下面的结果为 \u002Fregister?plan=private -->\n",[927,1919,1920,1922,1924,1926,1928,1930,1932,1935,1938,1941,1944,1946,1948,1951,1953],{"class":929,"line":1113},[927,1921,1343],{"class":1000},[927,1923,1347],{"class":1346},[927,1925,1554],{"class":1000},[927,1927,1401],{"class":933},[927,1929,1353],{"class":1000},[927,1931,1406],{"class":937},[927,1933,1934],{"class":1000},"{ path: ",[927,1936,1937],{"class":937},"'register'",[927,1939,1940],{"class":1000},", query: { plan: ",[927,1942,1943],{"class":937},"'private'",[927,1945,1899],{"class":1000},[927,1947,1406],{"class":937},[927,1949,1950],{"class":1000},">Register\u003C\u002F",[927,1952,1347],{"class":1346},[927,1954,1359],{"class":1000},[914,1956],{"title":1957},"与路由一样，to 属性在实现跳转功能的同时，也能传递参数",[1318,1959,1961],{"id":1960},"replace-属性","Replace 属性",[896,1963,1964],{},"设置 replace 属性的话，当点击时，会调用 router.replace() 而不是 router.push()，导航后不会留下 history 记录。",[918,1966,1968],{"className":1329,"code":1967,"language":1331,"meta":11,"style":11},"\u003Crouter-link :to=\"{ path: '\u002Fabc'}\" replace>\u003C\u002Frouter-link>\n",[924,1969,1970],{"__ignoreMap":11},[927,1971,1972,1974,1976,1978,1980,1982,1984,1986,1989,1992,1994,1997,2000,2002],{"class":929,"line":930},[927,1973,1343],{"class":1000},[927,1975,1347],{"class":1346},[927,1977,1554],{"class":1000},[927,1979,1401],{"class":933},[927,1981,1353],{"class":1000},[927,1983,1406],{"class":937},[927,1985,1934],{"class":1000},[927,1987,1988],{"class":937},"'\u002Fabc'",[927,1990,1991],{"class":1000},"}",[927,1993,1406],{"class":937},[927,1995,1996],{"class":933}," replace",[927,1998,1999],{"class":1000},">\u003C\u002F",[927,2001,1347],{"class":1346},[927,2003,1359],{"class":1000},[1318,2005,2007],{"id":2006},"append-属性","Append 属性",[896,2009,2010],{},"设置 append 属性后，则在当前 (相对) 路径前添加其路径。例如，我们从 \u002Fa 导航到一个相对路径 b，如果没有配置 append，则路径为 \u002Fb，如果配了，则为 \u002Fa\u002Fb",[918,2012,2014],{"className":1329,"code":2013,"language":1331,"meta":11,"style":11},"\u003Crouter-link :to=\"{ path: 'relative\u002Fpath'}\" append>\u003C\u002Frouter-link>\n",[924,2015,2016],{"__ignoreMap":11},[927,2017,2018,2020,2022,2024,2026,2028,2030,2032,2035,2037,2039,2042,2044,2046],{"class":929,"line":930},[927,2019,1343],{"class":1000},[927,2021,1347],{"class":1346},[927,2023,1554],{"class":1000},[927,2025,1401],{"class":933},[927,2027,1353],{"class":1000},[927,2029,1406],{"class":937},[927,2031,1934],{"class":1000},[927,2033,2034],{"class":937},"'relative\u002Fpath'",[927,2036,1991],{"class":1000},[927,2038,1406],{"class":937},[927,2040,2041],{"class":933}," append",[927,2043,1999],{"class":1000},[927,2045,1347],{"class":1346},[927,2047,1359],{"class":1000},[1318,2049,2051],{"id":2050},"tag-属性","Tag 属性",[896,2053,2054,2055,2057,2058,2061],{},"有时候想要 ",[924,2056,1729],{}," 渲染成某种标签，例如",[924,2059,2060],{},"\u003Cli>","。 于是我们使用 tag prop 类指定何种标签，同样它还是会监听点击，触发导航。",[918,2063,2065],{"className":1329,"code":2064,"language":1331,"meta":11,"style":11},"\u003Crouter-link to=\"\u002Ffoo\" tag=\"li\">foo\u003C\u002Frouter-link>\n\u003C!-- 渲染结果 -->\n\u003Cli>foo\u003C\u002Fli>\n",[924,2066,2067,2095,2100],{"__ignoreMap":11},[927,2068,2069,2071,2073,2075,2077,2080,2083,2085,2088,2091,2093],{"class":929,"line":930},[927,2070,1343],{"class":1000},[927,2072,1347],{"class":1346},[927,2074,1350],{"class":933},[927,2076,1353],{"class":1000},[927,2078,2079],{"class":937},"\"\u002Ffoo\"",[927,2081,2082],{"class":933}," tag",[927,2084,1353],{"class":1000},[927,2086,2087],{"class":937},"\"li\"",[927,2089,2090],{"class":1000},">foo\u003C\u002F",[927,2092,1347],{"class":1346},[927,2094,1359],{"class":1000},[927,2096,2097],{"class":929,"line":1010},[927,2098,2099],{"class":1064},"\u003C!-- 渲染结果 -->\n",[927,2101,2102,2104,2106,2108,2110],{"class":929,"line":1017},[927,2103,1343],{"class":1000},[927,2105,1299],{"class":1346},[927,2107,2090],{"class":1000},[927,2109,1299],{"class":1346},[927,2111,1359],{"class":1000},[1318,2113,2115],{"id":2114},"active-class-属性","Active-class 属性",[896,2117,2118],{},"设置 链接激活时使用的 CSS 类名。可以通过以下代码来替代。",[918,2120,2122],{"className":1329,"code":2121,"language":1331,"meta":11,"style":11},"\u003Cstyle>\n   ._active{\n      background-color : red;\n   }\n\u003C\u002Fstyle>\n\u003Cp>\n   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute1'}\" active-class = \"_active\">Router Link 1\u003C\u002Frouter-link>\n   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute2'}\" tag = \"span\">Router Link 2\u003C\u002Frouter-link>\n\u003C\u002Fp>\n",[924,2123,2124,2133,2140,2154,2159,2167,2175,2180,2185],{"__ignoreMap":11},[927,2125,2126,2128,2131],{"class":929,"line":930},[927,2127,1343],{"class":1000},[927,2129,2130],{"class":1346},"style",[927,2132,1359],{"class":1000},[927,2134,2135,2138],{"class":929,"line":1010},[927,2136,2137],{"class":933},"   ._active",[927,2139,1409],{"class":1000},[927,2141,2142,2145,2148,2151],{"class":929,"line":1017},[927,2143,2144],{"class":1074},"      background-color",[927,2146,2147],{"class":1000}," : ",[927,2149,2150],{"class":1074},"red",[927,2152,2153],{"class":1000},";\n",[927,2155,2156],{"class":929,"line":1030},[927,2157,2158],{"class":1000},"   }\n",[927,2160,2161,2163,2165],{"class":929,"line":1043},[927,2162,1369],{"class":1000},[927,2164,2130],{"class":1346},[927,2166,1359],{"class":1000},[927,2168,2169,2171,2173],{"class":929,"line":1056},[927,2170,1343],{"class":1000},[927,2172,896],{"class":1346},[927,2174,1359],{"class":1000},[927,2176,2177],{"class":929,"line":1061},[927,2178,2179],{"class":1000},"   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute1'}\" active-class = \"_active\">Router Link 1\u003C\u002Frouter-link>\n",[927,2181,2182],{"class":929,"line":1068},[927,2183,2184],{"class":1000},"   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute2'}\" tag = \"span\">Router Link 2\u003C\u002Frouter-link>\n",[927,2186,2187,2189,2191],{"class":929,"line":1084},[927,2188,1369],{"class":1000},[927,2190,896],{"class":1346},[927,2192,1359],{"class":1000},[896,2194,2195],{},"注意这里 class 使用 active-class=\"_active\"。",[1318,2197,2199],{"id":2198},"exact-active-class-属性","Exact-active-class 属性",[896,2201,2202],{},"配置当链接被精确匹配的时候应该激活的 class。可以通过以下代码来替代。",[918,2204,2206],{"className":1329,"code":2205,"language":1331,"meta":11,"style":11},"\u003Cp>\n   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute1'}\" exact-active-class = \"_active\">Router Link 1\u003C\u002Frouter-link>\n   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute2'}\" tag = \"span\">Router Link 2\u003C\u002Frouter-link>\n\u003C\u002Fp>\n",[924,2207,2208,2216,2221,2225],{"__ignoreMap":11},[927,2209,2210,2212,2214],{"class":929,"line":930},[927,2211,1343],{"class":1000},[927,2213,896],{"class":1346},[927,2215,1359],{"class":1000},[927,2217,2218],{"class":929,"line":1010},[927,2219,2220],{"class":1000},"   \u003Crouter-link v-bind:to = \"{ path: '\u002Froute1'}\" exact-active-class = \"_active\">Router Link 1\u003C\u002Frouter-link>\n",[927,2222,2223],{"class":929,"line":1017},[927,2224,2184],{"class":1000},[927,2226,2227,2229,2231],{"class":929,"line":1030},[927,2228,1369],{"class":1000},[927,2230,896],{"class":1346},[927,2232,1359],{"class":1000},[1318,2234,2236],{"id":2235},"event-属性","Event 属性",[896,2238,2239],{},"声明可以用来触发导航的事件。可以是一个字符串或是一个包含字符串的数组。",[918,2241,2243],{"className":1329,"code":2242,"language":1331,"meta":11,"style":11},"\u003Crouter-link v-bind:to = \"{ path: '\u002Froute1'}\" event = \"mouseover\">Router Link 1\u003C\u002Frouter-link>\n",[924,2244,2245],{"__ignoreMap":11},[927,2246,2247,2249,2251,2254,2257,2259,2262,2264,2266,2269,2271,2273,2276,2278,2281,2284,2286],{"class":929,"line":930},[927,2248,1343],{"class":1000},[927,2250,1347],{"class":1346},[927,2252,2253],{"class":933}," v-bind",[927,2255,2256],{"class":1000},":",[927,2258,1401],{"class":933},[927,2260,2261],{"class":1000}," = ",[927,2263,1406],{"class":937},[927,2265,1934],{"class":1000},[927,2267,2268],{"class":937},"'\u002Froute1'",[927,2270,1991],{"class":1000},[927,2272,1406],{"class":937},[927,2274,2275],{"class":933}," event",[927,2277,2261],{"class":1000},[927,2279,2280],{"class":937},"\"mouseover\"",[927,2282,2283],{"class":1000},">Router Link 1\u003C\u002F",[927,2285,1347],{"class":1346},[927,2287,1359],{"class":1000},[896,2289,2290],{},"以上代码设置了 event 为 mouseover ，及在鼠标移动到 Router Link 1 上时导航的 HTML 内容会发生改变。",[892,2292,2294],{"id":2293},"routerview","RouterView",[896,2296,2297],{},"router-view 将显示与 url 对应的组件。你可以把他看做一个盒子，用来存放路由展示的组件，根据不同的 URL 显示不同的组件。所以你可以把它放在任何地方，以适应你的布局。",[918,2299,2301],{"className":1329,"code":2300,"language":1331,"meta":11,"style":11},"\u003Crouter-view>\u003C\u002Frouter-view>\n",[924,2302,2303],{"__ignoreMap":11},[927,2304,2305,2307,2310,2312,2314],{"class":929,"line":930},[927,2306,1343],{"class":1000},[927,2308,2309],{"class":1346},"router-view",[927,2311,1999],{"class":1000},[927,2313,2309],{"class":1346},[927,2315,1359],{"class":1000},[896,2317,2318,2319,2322],{},"点击过的导航链接都会加上样式 ",[924,2320,2321],{},"class =\"router-link-exact-active router-link-active\"","。",[903,2324],{"title":2325},"\u003Crouter-link> 和 \u003Crouter-link> 也可以写成 \u003CRouterLink> 和 \u003CRouterView> 这种组件形式",[892,2327,2328],{"id":2328},"工作模式",[896,2330,2331],{},"在 Vue3 中路由器有两种工作模式，分别为 history 模式、hash 模式。",[2333,2334,2335],"ol",{},[1299,2336,2337],{},"History 模式",[918,2339,2343],{"className":2340,"code":2341,"language":2342,"meta":11,"style":11},"language-js shiki shiki-themes github-light github-light github-dark","const router = createRouter({\n    history:createWebHistory(), \n    \u002F******\u002F\n})\n","js",[924,2344,2345,2357,2367,2372],{"__ignoreMap":11},[927,2346,2347,2349,2351,2353,2355],{"class":929,"line":930},[927,2348,1071],{"class":996},[927,2350,1236],{"class":1074},[927,2352,1078],{"class":996},[927,2354,1241],{"class":933},[927,2356,1244],{"class":1000},[927,2358,2359,2362,2364],{"class":929,"line":1010},[927,2360,2361],{"class":1000},"    history:",[927,2363,1259],{"class":933},[927,2365,2366],{"class":1000},"(), \n",[927,2368,2369],{"class":929,"line":1017},[927,2370,2371],{"class":1064},"    \u002F******\u002F\n",[927,2373,2374],{"class":929,"line":1030},[927,2375,2376],{"class":1000},"})\n",[1296,2378,2379,2382],{},[1299,2380,2381],{},"优点：URL 美观，不带 # ，更接近传统的网站 URL",[1299,2383,2384],{},"缺点：项目上线后，需要服务端配合处理路径问题",[2333,2386,2387],{"start":1010},[1299,2388,2389],{},"Hash 模式",[918,2391,2393],{"className":2340,"code":2392,"language":2342,"meta":11,"style":11},"const router = createRouter({\n    history:createWebHashHistory(), \n    \u002F******\u002F\n})\n",[924,2394,2395,2407,2416,2420],{"__ignoreMap":11},[927,2396,2397,2399,2401,2403,2405],{"class":929,"line":930},[927,2398,1071],{"class":996},[927,2400,1236],{"class":1074},[927,2402,1078],{"class":996},[927,2404,1241],{"class":933},[927,2406,1244],{"class":1000},[927,2408,2409,2411,2414],{"class":929,"line":1010},[927,2410,2361],{"class":1000},[927,2412,2413],{"class":933},"createWebHashHistory",[927,2415,2366],{"class":1000},[927,2417,2418],{"class":929,"line":1017},[927,2419,2371],{"class":1064},[927,2421,2422],{"class":929,"line":1030},[927,2423,2376],{"class":1000},[1296,2425,2426,2429],{},[1299,2427,2428],{},"优点：兼容性更好，不需要服务器配合处理",[1299,2430,2431],{},"缺点：URL 带有 #，不美观，不利于搜索引擎优化。",[892,2433,2434],{"id":2434},"重定向",[896,2436,2437,2438,2441,2442,2445,2446,2448],{},"默认直接访问项目都是请求 ",[924,2439,2440],{},"\u002F"," 这个 URL 的路由，如果想直接进入其他路由时，可以直接将对应路由的 ",[924,2443,2444],{},"path"," 改为 ",[924,2447,2440],{},"，但是这样做不便于代码的阅读和后期的维护。为了解决这个问题，可以使用 redirect 进行路由重定向。",[2333,2450,2451],{},[1299,2452,2453],{},"使用路径重定向，直接重定向到指定的 URL。",[918,2455,2457],{"className":2340,"code":2456,"language":2342,"meta":11,"style":11},"const routes = [\n    { path : '\u002F', redirect : '\u002Fnews'}\n]\n",[924,2458,2459,2469,2484],{"__ignoreMap":11},[927,2460,2461,2463,2465,2467],{"class":929,"line":930},[927,2462,1071],{"class":996},[927,2464,1075],{"class":1074},[927,2466,1078],{"class":996},[927,2468,1081],{"class":1000},[927,2470,2471,2474,2476,2479,2481],{"class":929,"line":1010},[927,2472,2473],{"class":1000},"    { path : ",[927,2475,1096],{"class":937},[927,2477,2478],{"class":1000},", redirect : ",[927,2480,1135],{"class":937},[927,2482,2483],{"class":1000},"}\n",[927,2485,2486],{"class":929,"line":1017},[927,2487,2488],{"class":1000},"]\n",[2333,2490,2491],{"start":1010},[1299,2492,2493],{},"使用命名的路由重定向，重定向到一个指定名称的路由",[918,2495,2497],{"className":2340,"code":2496,"language":2342,"meta":11,"style":11},"const routes = [\n    { path : \"\u002F\", redirect : { name : 'news'} }\n]\n",[924,2498,2499,2509,2524],{"__ignoreMap":11},[927,2500,2501,2503,2505,2507],{"class":929,"line":930},[927,2502,1071],{"class":996},[927,2504,1075],{"class":1074},[927,2506,1078],{"class":996},[927,2508,1081],{"class":1000},[927,2510,2511,2513,2516,2519,2521],{"class":929,"line":1010},[927,2512,2473],{"class":1000},[927,2514,2515],{"class":937},"\"\u002F\"",[927,2517,2518],{"class":1000},", redirect : { name : ",[927,2520,1145],{"class":937},[927,2522,2523],{"class":1000},"} }\n",[927,2525,2526],{"class":929,"line":1017},[927,2527,2488],{"class":1000},[2333,2529,2530],{"start":1017},[1299,2531,2532],{},"重定向时也可以传参",[918,2534,2536],{"className":2340,"code":2535,"language":2342,"meta":11,"style":11},"const routes = [\n    { path : \"\u002F\", redirect : to => {  \n        \u002F\u002F 使用编程式导航进行重定向，并附带查询参数  \n        return {  \n            path: '\u002Fnews',  \n            query: {  \n                title: 'Hello CoderMast!',  \n                context: '你好 CoderMast!'  \n            }  \n        }  \n      }   \n    }\n]\n",[924,2537,2538,2548,2570,2575,2582,2592,2597,2607,2618,2623,2628,2633,2637],{"__ignoreMap":11},[927,2539,2540,2542,2544,2546],{"class":929,"line":930},[927,2541,1071],{"class":996},[927,2543,1075],{"class":1074},[927,2545,1078],{"class":996},[927,2547,1081],{"class":1000},[927,2549,2550,2552,2554,2556,2559,2561,2564,2567],{"class":929,"line":1010},[927,2551,2473],{"class":1000},[927,2553,2515],{"class":937},[927,2555,1609],{"class":1000},[927,2557,2558],{"class":933},"redirect",[927,2560,2147],{"class":1000},[927,2562,1401],{"class":2563},"sP4rz",[927,2565,2566],{"class":996}," =>",[927,2568,2569],{"class":1000}," {  \n",[927,2571,2572],{"class":929,"line":1017},[927,2573,2574],{"class":1064},"        \u002F\u002F 使用编程式导航进行重定向，并附带查询参数  \n",[927,2576,2577,2580],{"class":929,"line":1030},[927,2578,2579],{"class":996},"        return",[927,2581,2569],{"class":1000},[927,2583,2584,2587,2589],{"class":929,"line":1043},[927,2585,2586],{"class":1000},"            path: ",[927,2588,1135],{"class":937},[927,2590,2591],{"class":1000},",  \n",[927,2593,2594],{"class":929,"line":1056},[927,2595,2596],{"class":1000},"            query: {  \n",[927,2598,2599,2602,2605],{"class":929,"line":1061},[927,2600,2601],{"class":1000},"                title: ",[927,2603,2604],{"class":937},"'Hello CoderMast!'",[927,2606,2591],{"class":1000},[927,2608,2609,2612,2615],{"class":929,"line":1068},[927,2610,2611],{"class":1000},"                context: ",[927,2613,2614],{"class":937},"'你好 CoderMast!'",[927,2616,2617],{"class":1000},"  \n",[927,2619,2620],{"class":929,"line":1084},[927,2621,2622],{"class":1000},"            }  \n",[927,2624,2625],{"class":929,"line":1090},[927,2626,2627],{"class":1000},"        }  \n",[927,2629,2630],{"class":929,"line":1102},[927,2631,2632],{"class":1000},"      }   \n",[927,2634,2635],{"class":929,"line":1113},[927,2636,1211],{"class":1000},[927,2638,2639],{"class":929,"line":1119},[927,2640,2488],{"class":1000},[892,2642,2643],{"id":2643},"编程式导航",[896,2645,2646],{},"上面的方式否是通过标签来进行路由控制，但是在实际的开发中经常遇到的一种情况就是，需要通过脚本的执行来进行路由控制。",[896,2648,2649],{},"例如，控制用户在登录成功后，自动跳转到用户中心。这就无法使用上述标签来实现，这该如何解决呢？",[896,2651,2652,2653,2656,2657,2660,2661,2664,2665,2668],{},"在 Vue3 中 可以使用 vue-router 插件中提供的两个方法 ",[924,2654,2655],{},"useRoute"," 和 ",[924,2658,2659],{},"useRouter","，这和 Vue2 中的 ",[924,2662,2663],{},"$route","和",[924,2666,2667],{},"$router"," 类似。",[896,2670,2671],{},"具体的跳转方式有 push 和 replace 两种，和之前说过的用法一致，不过多赘述。",[914,2673,2674],{},"\n[点击跳转到 replace 属性](#replace-属性)\n",[918,2676,2678],{"className":1329,"code":2677,"language":1331,"meta":11,"style":11},"\u003Ctemplate>\n  \u003Cdiv class=\"app\">\n    \u003Ch2>Vue 编程式路由测试\u003C\u002Fh2>\n  \u003C\u002Fdiv>\n\u003C\u002Ftemplate>\n\n\u003Cscript lang=\"ts\" setup>\nimport { onMounted } from 'vue'\nimport { useRouter } from 'vue-router'  \n\nconst router = useRouter();\n\n\u002F\u002F 在页面成功挂载后 3 秒进行路由跳转\nonMounted(()=> {\n   setTimeout(() => {\n      \u002F\u002F 跳转到 \"\u002Fnews\" 路由\n      router.push(\"\u002Fnews\")    \u002F\u002F 有痕跳转\n      router.replace(\"\u002Fnews\") \u002F\u002F 无痕跳转\n   },3000)\n})\n\u003C\u002Fscript>\n",[924,2679,2680,2689,2707,2721,2729,2737,2741,2761,2773,2787,2791,2805,2809,2814,2828,2840,2845,2865,2882,2893,2897],{"__ignoreMap":11},[927,2681,2682,2684,2687],{"class":929,"line":930},[927,2683,1343],{"class":1000},[927,2685,2686],{"class":1346},"template",[927,2688,1359],{"class":1000},[927,2690,2691,2694,2697,2700,2702,2705],{"class":929,"line":1010},[927,2692,2693],{"class":1000},"  \u003C",[927,2695,2696],{"class":1346},"div",[927,2698,2699],{"class":933}," class",[927,2701,1353],{"class":1000},[927,2703,2704],{"class":937},"\"app\"",[927,2706,1359],{"class":1000},[927,2708,2709,2712,2714,2717,2719],{"class":929,"line":1017},[927,2710,2711],{"class":1000},"    \u003C",[927,2713,892],{"class":1346},[927,2715,2716],{"class":1000},">Vue 编程式路由测试\u003C\u002F",[927,2718,892],{"class":1346},[927,2720,1359],{"class":1000},[927,2722,2723,2725,2727],{"class":929,"line":1030},[927,2724,1659],{"class":1000},[927,2726,2696],{"class":1346},[927,2728,1359],{"class":1000},[927,2730,2731,2733,2735],{"class":929,"line":1043},[927,2732,1369],{"class":1000},[927,2734,2686],{"class":1346},[927,2736,1359],{"class":1000},[927,2738,2739],{"class":929,"line":1056},[927,2740,1014],{"emptyLinePlaceholder":1013},[927,2742,2743,2745,2748,2751,2753,2756,2759],{"class":929,"line":1061},[927,2744,1343],{"class":1000},[927,2746,2747],{"class":1346},"script",[927,2749,2750],{"class":933}," lang",[927,2752,1353],{"class":1000},[927,2754,2755],{"class":937},"\"ts\"",[927,2757,2758],{"class":933}," setup",[927,2760,1359],{"class":1000},[927,2762,2763,2765,2768,2770],{"class":929,"line":1068},[927,2764,997],{"class":996},[927,2766,2767],{"class":1000}," { onMounted } ",[927,2769,1004],{"class":996},[927,2771,2772],{"class":937}," 'vue'\n",[927,2774,2775,2777,2780,2782,2785],{"class":929,"line":1084},[927,2776,997],{"class":996},[927,2778,2779],{"class":1000}," { useRouter } ",[927,2781,1004],{"class":996},[927,2783,2784],{"class":937}," 'vue-router'",[927,2786,2617],{"class":1000},[927,2788,2789],{"class":929,"line":1090},[927,2790,1014],{"emptyLinePlaceholder":1013},[927,2792,2793,2795,2797,2799,2802],{"class":929,"line":1102},[927,2794,1071],{"class":996},[927,2796,1236],{"class":1074},[927,2798,1078],{"class":996},[927,2800,2801],{"class":933}," useRouter",[927,2803,2804],{"class":1000},"();\n",[927,2806,2807],{"class":929,"line":1113},[927,2808,1014],{"emptyLinePlaceholder":1013},[927,2810,2811],{"class":929,"line":1119},[927,2812,2813],{"class":1064},"\u002F\u002F 在页面成功挂载后 3 秒进行路由跳转\n",[927,2815,2816,2819,2822,2825],{"class":929,"line":1125},[927,2817,2818],{"class":933},"onMounted",[927,2820,2821],{"class":1000},"(()",[927,2823,2824],{"class":996},"=>",[927,2826,2827],{"class":1000}," {\n",[927,2829,2830,2833,2836,2838],{"class":929,"line":1130},[927,2831,2832],{"class":933},"   setTimeout",[927,2834,2835],{"class":1000},"(() ",[927,2837,2824],{"class":996},[927,2839,2827],{"class":1000},[927,2841,2842],{"class":929,"line":1140},[927,2843,2844],{"class":1064},"      \u002F\u002F 跳转到 \"\u002Fnews\" 路由\n",[927,2846,2847,2850,2853,2856,2859,2862],{"class":929,"line":1150},[927,2848,2849],{"class":1000},"      router.",[927,2851,2852],{"class":933},"push",[927,2854,2855],{"class":1000},"(",[927,2857,2858],{"class":937},"\"\u002Fnews\"",[927,2860,2861],{"class":1000},")    ",[927,2863,2864],{"class":1064},"\u002F\u002F 有痕跳转\n",[927,2866,2867,2869,2872,2874,2876,2879],{"class":929,"line":1156},[927,2868,2849],{"class":1000},[927,2870,2871],{"class":933},"replace",[927,2873,2855],{"class":1000},[927,2875,2858],{"class":937},[927,2877,2878],{"class":1000},") ",[927,2880,2881],{"class":1064},"\u002F\u002F 无痕跳转\n",[927,2883,2884,2887,2890],{"class":929,"line":1162},[927,2885,2886],{"class":1000},"   },",[927,2888,2889],{"class":1074},"3000",[927,2891,2892],{"class":1000},")\n",[927,2894,2895],{"class":929,"line":1168},[927,2896,2376],{"class":1000},[927,2898,2899,2901,2903],{"class":929,"line":1179},[927,2900,1369],{"class":1000},[927,2902,2747],{"class":1346},[927,2904,1359],{"class":1000},[903,2906],{"title":2907},"实际的开发中，使用编程式导航的情况远远大于链接式。",[892,2909,2910],{"id":2910},"使用",[896,2912,2913],{},"在使用路由之前，需要先进行配置注册。",[2333,2915,2916],{},[1299,2917,2918,2919],{},"创建路由配置文件 ",[924,2920,984],{},[918,2922,2924],{"className":987,"code":2923,"language":989,"meta":11,"style":11},"import { createRouter,createWebHistory } from 'vue-router'\n\nimport Home from '..\u002Fpages\u002FHome.vue'\nimport News from '..\u002Fpages\u002FNews.vue'\n\n\u002F\u002F 构建路由映射对象\nconst routes = [\n    {\n        path: '\u002F',\n        name: 'home',\n        component: Home\n    },\n    {\n        path: '\u002Fnews',\n        name: 'news',\n        component: News\n    }\n];\n\n\u002F\u002F 创建路由对象\nconst router = createRouter({\n    \u002F\u002F 配置路由器模式\n    history: createWebHistory(),\n    routes\n});\n\nexport default router\n",[924,2925,2926,2936,2940,2950,2960,2964,2968,2978,2982,2990,2998,3002,3006,3010,3018,3026,3031,3035,3039,3043,3047,3059,3063,3071,3075,3079,3083],{"__ignoreMap":11},[927,2927,2928,2930,2932,2934],{"class":929,"line":930},[927,2929,997],{"class":996},[927,2931,1001],{"class":1000},[927,2933,1004],{"class":996},[927,2935,1007],{"class":937},[927,2937,2938],{"class":929,"line":1010},[927,2939,1014],{"emptyLinePlaceholder":1013},[927,2941,2942,2944,2946,2948],{"class":929,"line":1017},[927,2943,997],{"class":996},[927,2945,1022],{"class":1000},[927,2947,1004],{"class":996},[927,2949,1027],{"class":937},[927,2951,2952,2954,2956,2958],{"class":929,"line":1030},[927,2953,997],{"class":996},[927,2955,1035],{"class":1000},[927,2957,1004],{"class":996},[927,2959,1040],{"class":937},[927,2961,2962],{"class":929,"line":1043},[927,2963,1014],{"emptyLinePlaceholder":1013},[927,2965,2966],{"class":929,"line":1056},[927,2967,1065],{"class":1064},[927,2969,2970,2972,2974,2976],{"class":929,"line":1061},[927,2971,1071],{"class":996},[927,2973,1075],{"class":1074},[927,2975,1078],{"class":996},[927,2977,1081],{"class":1000},[927,2979,2980],{"class":929,"line":1068},[927,2981,1087],{"class":1000},[927,2983,2984,2986,2988],{"class":929,"line":1084},[927,2985,1093],{"class":1000},[927,2987,1096],{"class":937},[927,2989,1099],{"class":1000},[927,2991,2992,2994,2996],{"class":929,"line":1090},[927,2993,1105],{"class":1000},[927,2995,1108],{"class":937},[927,2997,1099],{"class":1000},[927,2999,3000],{"class":929,"line":1102},[927,3001,1116],{"class":1000},[927,3003,3004],{"class":929,"line":1113},[927,3005,1122],{"class":1000},[927,3007,3008],{"class":929,"line":1119},[927,3009,1087],{"class":1000},[927,3011,3012,3014,3016],{"class":929,"line":1125},[927,3013,1093],{"class":1000},[927,3015,1135],{"class":937},[927,3017,1099],{"class":1000},[927,3019,3020,3022,3024],{"class":929,"line":1130},[927,3021,1105],{"class":1000},[927,3023,1145],{"class":937},[927,3025,1099],{"class":1000},[927,3027,3028],{"class":929,"line":1140},[927,3029,3030],{"class":1000},"        component: News\n",[927,3032,3033],{"class":929,"line":1150},[927,3034,1211],{"class":1000},[927,3036,3037],{"class":929,"line":1156},[927,3038,1217],{"class":1000},[927,3040,3041],{"class":929,"line":1162},[927,3042,1014],{"emptyLinePlaceholder":1013},[927,3044,3045],{"class":929,"line":1168},[927,3046,1228],{"class":1064},[927,3048,3049,3051,3053,3055,3057],{"class":929,"line":1179},[927,3050,1071],{"class":996},[927,3052,1236],{"class":1074},[927,3054,1078],{"class":996},[927,3056,1241],{"class":933},[927,3058,1244],{"class":1000},[927,3060,3061],{"class":929,"line":1190},[927,3062,1250],{"class":1064},[927,3064,3065,3067,3069],{"class":929,"line":1196},[927,3066,1256],{"class":1000},[927,3068,1259],{"class":933},[927,3070,1262],{"class":1000},[927,3072,3073],{"class":929,"line":1202},[927,3074,1268],{"class":1000},[927,3076,3077],{"class":929,"line":1208},[927,3078,1274],{"class":1000},[927,3080,3081],{"class":929,"line":1214},[927,3082,1014],{"emptyLinePlaceholder":1013},[927,3084,3085,3087,3089],{"class":929,"line":1220},[927,3086,1285],{"class":996},[927,3088,1288],{"class":996},[927,3090,1291],{"class":1000},[2333,3092,3093],{"start":1010},[1299,3094,3095],{},"在 main.ts 中进行注册",[918,3097,3099],{"className":987,"code":3098,"language":989,"meta":11,"style":11},"import { createApp } from 'vue'\n\nimport Home from '@\u002Fcomponents\u002FHome.vue'\nimport router from '@\u002Frouter\u002Findex';\n\nconst app = createApp(Home);\napp.use(router);\napp.mount('#app');\n",[924,3100,3101,3112,3116,3127,3141,3145,3160,3171],{"__ignoreMap":11},[927,3102,3103,3105,3108,3110],{"class":929,"line":930},[927,3104,997],{"class":996},[927,3106,3107],{"class":1000}," { createApp } ",[927,3109,1004],{"class":996},[927,3111,2772],{"class":937},[927,3113,3114],{"class":929,"line":1010},[927,3115,1014],{"emptyLinePlaceholder":1013},[927,3117,3118,3120,3122,3124],{"class":929,"line":1017},[927,3119,997],{"class":996},[927,3121,1022],{"class":1000},[927,3123,1004],{"class":996},[927,3125,3126],{"class":937}," '@\u002Fcomponents\u002FHome.vue'\n",[927,3128,3129,3131,3134,3136,3139],{"class":929,"line":1030},[927,3130,997],{"class":996},[927,3132,3133],{"class":1000}," router ",[927,3135,1004],{"class":996},[927,3137,3138],{"class":937}," '@\u002Frouter\u002Findex'",[927,3140,2153],{"class":1000},[927,3142,3143],{"class":929,"line":1043},[927,3144,1014],{"emptyLinePlaceholder":1013},[927,3146,3147,3149,3152,3154,3157],{"class":929,"line":1056},[927,3148,1071],{"class":996},[927,3150,3151],{"class":1074}," app",[927,3153,1078],{"class":996},[927,3155,3156],{"class":933}," createApp",[927,3158,3159],{"class":1000},"(Home);\n",[927,3161,3162,3165,3168],{"class":929,"line":1061},[927,3163,3164],{"class":1000},"app.",[927,3166,3167],{"class":933},"use",[927,3169,3170],{"class":1000},"(router);\n",[927,3172,3173,3175,3178,3180,3183],{"class":929,"line":1068},[927,3174,3164],{"class":1000},[927,3176,3177],{"class":933},"mount",[927,3179,2855],{"class":1000},[927,3181,3182],{"class":937},"'#app'",[927,3184,3185],{"class":1000},");\n",[2333,3187,3188],{"start":1017},[1299,3189,3190],{},"在组件中使用",[918,3192,3194],{"className":1329,"code":3193,"language":1331,"meta":11,"style":11},"\u003Ctemplate>\n  \u003Cdiv class=\"app\">\n    \u003Ch2 class=\"title\">Vue路由测试\u003C\u002Fh2>\n    \u003C!-- 导航区 -->\n    \u003Cdiv class=\"navigate\">\n        \u003CRouterLink to=\"\u002Fhome\" active-class=\"active\">首页\u003C\u002FRouterLink>\n        \u003CRouterLink to=\"\u002Fnews\" active-class=\"active\">新闻\u003C\u002FRouterLink>\n    \u003C\u002Fdiv>\n    \u003C!-- 展示区 -->\n    \u003Cdiv class=\"main-content\">\n        \u003CRouterView>\u003C\u002FRouterView>\n    \u003C\u002Fdiv>\n  \u003C\u002Fdiv>\n\u003C\u002Ftemplate>\n\n\u003Cscript lang=\"ts\" setup>\nimport { RouterLink, RouterView, useRouter } from 'vue-router'  \n\nimport { onMounted } from 'vue'\n\nconst router = useRouter();\n\n\u002F\u002F 在页面成功挂载后 3 秒进行路由跳转\nonMounted(()=> {\n   setTimeout(() => {\n      \u002F\u002F 跳转到 \"\u002Fnews\" 路由\n      router.push(\"\u002Fnews\")    \u002F\u002F 有痕跳转\n      router.replace(\"\u002Fnews\") \u002F\u002F 无痕跳转\n   },3000)\n})\n\u003C\u002Fscript>\n",[924,3195,3196,3204,3218,3238,3243,3258,3284,3308,3317,3322,3337,3349,3357,3365,3373,3377,3393,3406,3410,3420,3424,3436,3440,3444,3454,3464,3468,3482,3496,3504,3508],{"__ignoreMap":11},[927,3197,3198,3200,3202],{"class":929,"line":930},[927,3199,1343],{"class":1000},[927,3201,2686],{"class":1346},[927,3203,1359],{"class":1000},[927,3205,3206,3208,3210,3212,3214,3216],{"class":929,"line":1010},[927,3207,2693],{"class":1000},[927,3209,2696],{"class":1346},[927,3211,2699],{"class":933},[927,3213,1353],{"class":1000},[927,3215,2704],{"class":937},[927,3217,1359],{"class":1000},[927,3219,3220,3222,3224,3226,3228,3231,3234,3236],{"class":929,"line":1017},[927,3221,2711],{"class":1000},[927,3223,892],{"class":1346},[927,3225,2699],{"class":933},[927,3227,1353],{"class":1000},[927,3229,3230],{"class":937},"\"title\"",[927,3232,3233],{"class":1000},">Vue路由测试\u003C\u002F",[927,3235,892],{"class":1346},[927,3237,1359],{"class":1000},[927,3239,3240],{"class":929,"line":1030},[927,3241,3242],{"class":1064},"    \u003C!-- 导航区 -->\n",[927,3244,3245,3247,3249,3251,3253,3256],{"class":929,"line":1043},[927,3246,2711],{"class":1000},[927,3248,2696],{"class":1346},[927,3250,2699],{"class":933},[927,3252,1353],{"class":1000},[927,3254,3255],{"class":937},"\"navigate\"",[927,3257,1359],{"class":1000},[927,3259,3260,3263,3265,3267,3269,3271,3273,3275,3277,3280,3282],{"class":929,"line":1056},[927,3261,3262],{"class":1000},"        \u003C",[927,3264,1390],{"class":1346},[927,3266,1350],{"class":933},[927,3268,1353],{"class":1000},[927,3270,1771],{"class":937},[927,3272,1759],{"class":933},[927,3274,1353],{"class":1000},[927,3276,1764],{"class":937},[927,3278,3279],{"class":1000},">首页\u003C\u002F",[927,3281,1390],{"class":1346},[927,3283,1359],{"class":1000},[927,3285,3286,3288,3290,3292,3294,3296,3298,3300,3302,3304,3306],{"class":929,"line":1061},[927,3287,3262],{"class":1000},[927,3289,1390],{"class":1346},[927,3291,1350],{"class":933},[927,3293,1353],{"class":1000},[927,3295,2858],{"class":937},[927,3297,1759],{"class":933},[927,3299,1353],{"class":1000},[927,3301,1764],{"class":937},[927,3303,1857],{"class":1000},[927,3305,1390],{"class":1346},[927,3307,1359],{"class":1000},[927,3309,3310,3313,3315],{"class":929,"line":1068},[927,3311,3312],{"class":1000},"    \u003C\u002F",[927,3314,2696],{"class":1346},[927,3316,1359],{"class":1000},[927,3318,3319],{"class":929,"line":1084},[927,3320,3321],{"class":1064},"    \u003C!-- 展示区 -->\n",[927,3323,3324,3326,3328,3330,3332,3335],{"class":929,"line":1090},[927,3325,2711],{"class":1000},[927,3327,2696],{"class":1346},[927,3329,2699],{"class":933},[927,3331,1353],{"class":1000},[927,3333,3334],{"class":937},"\"main-content\"",[927,3336,1359],{"class":1000},[927,3338,3339,3341,3343,3345,3347],{"class":929,"line":1102},[927,3340,3262],{"class":1000},[927,3342,2294],{"class":1346},[927,3344,1999],{"class":1000},[927,3346,2294],{"class":1346},[927,3348,1359],{"class":1000},[927,3350,3351,3353,3355],{"class":929,"line":1113},[927,3352,3312],{"class":1000},[927,3354,2696],{"class":1346},[927,3356,1359],{"class":1000},[927,3358,3359,3361,3363],{"class":929,"line":1119},[927,3360,1659],{"class":1000},[927,3362,2696],{"class":1346},[927,3364,1359],{"class":1000},[927,3366,3367,3369,3371],{"class":929,"line":1125},[927,3368,1369],{"class":1000},[927,3370,2686],{"class":1346},[927,3372,1359],{"class":1000},[927,3374,3375],{"class":929,"line":1130},[927,3376,1014],{"emptyLinePlaceholder":1013},[927,3378,3379,3381,3383,3385,3387,3389,3391],{"class":929,"line":1140},[927,3380,1343],{"class":1000},[927,3382,2747],{"class":1346},[927,3384,2750],{"class":933},[927,3386,1353],{"class":1000},[927,3388,2755],{"class":937},[927,3390,2758],{"class":933},[927,3392,1359],{"class":1000},[927,3394,3395,3397,3400,3402,3404],{"class":929,"line":1150},[927,3396,997],{"class":996},[927,3398,3399],{"class":1000}," { RouterLink, RouterView, useRouter } ",[927,3401,1004],{"class":996},[927,3403,2784],{"class":937},[927,3405,2617],{"class":1000},[927,3407,3408],{"class":929,"line":1156},[927,3409,1014],{"emptyLinePlaceholder":1013},[927,3411,3412,3414,3416,3418],{"class":929,"line":1162},[927,3413,997],{"class":996},[927,3415,2767],{"class":1000},[927,3417,1004],{"class":996},[927,3419,2772],{"class":937},[927,3421,3422],{"class":929,"line":1168},[927,3423,1014],{"emptyLinePlaceholder":1013},[927,3425,3426,3428,3430,3432,3434],{"class":929,"line":1179},[927,3427,1071],{"class":996},[927,3429,1236],{"class":1074},[927,3431,1078],{"class":996},[927,3433,2801],{"class":933},[927,3435,2804],{"class":1000},[927,3437,3438],{"class":929,"line":1190},[927,3439,1014],{"emptyLinePlaceholder":1013},[927,3441,3442],{"class":929,"line":1196},[927,3443,2813],{"class":1064},[927,3445,3446,3448,3450,3452],{"class":929,"line":1202},[927,3447,2818],{"class":933},[927,3449,2821],{"class":1000},[927,3451,2824],{"class":996},[927,3453,2827],{"class":1000},[927,3455,3456,3458,3460,3462],{"class":929,"line":1208},[927,3457,2832],{"class":933},[927,3459,2835],{"class":1000},[927,3461,2824],{"class":996},[927,3463,2827],{"class":1000},[927,3465,3466],{"class":929,"line":1214},[927,3467,2844],{"class":1064},[927,3469,3470,3472,3474,3476,3478,3480],{"class":929,"line":1220},[927,3471,2849],{"class":1000},[927,3473,2852],{"class":933},[927,3475,2855],{"class":1000},[927,3477,2858],{"class":937},[927,3479,2861],{"class":1000},[927,3481,2864],{"class":1064},[927,3483,3484,3486,3488,3490,3492,3494],{"class":929,"line":1225},[927,3485,2849],{"class":1000},[927,3487,2871],{"class":933},[927,3489,2855],{"class":1000},[927,3491,2858],{"class":937},[927,3493,2878],{"class":1000},[927,3495,2881],{"class":1064},[927,3497,3498,3500,3502],{"class":929,"line":1231},[927,3499,2886],{"class":1000},[927,3501,2889],{"class":1074},[927,3503,2892],{"class":1000},[927,3505,3506],{"class":929,"line":1247},[927,3507,2376],{"class":1000},[927,3509,3510,3512,3514],{"class":929,"line":1253},[927,3511,1369],{"class":1000},[927,3513,2747],{"class":1346},[927,3515,1359],{"class":1000},[903,3517,3518,3519],{"title":1711},"\n1. 路由组件通常存放在`pages` 或 `views`文件夹，一般组件通常存放在`components`文件夹。\n",[2333,3520,3521],{"start":1010},[1299,3522,3523,3524,3528,3529,3532],{},"通过点击导航，视觉效果上“消失” 了的路由组件，默认是被",[3525,3526,3527],"strong",{},"卸载","掉的，需要的时候再去",[3525,3530,3531],{},"挂载","。\n\n",[2130,3534,3535],{},"html pre.shiki code .snPdu, html code.shiki .snPdu{--shiki-light:#6F42C1;--shiki-default:#6F42C1;--shiki-dark:#B392F0}html pre.shiki code .sIIMD, html code.shiki .sIIMD{--shiki-light:#032F62;--shiki-default:#032F62;--shiki-dark:#9ECBFF}html .light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html.light .shiki span {color: var(--shiki-light);background: var(--shiki-light-bg);font-style: var(--shiki-light-font-style);font-weight: var(--shiki-light-font-weight);text-decoration: var(--shiki-light-text-decoration);}html .default .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .shiki span {color: var(--shiki-default);background: var(--shiki-default-bg);font-style: var(--shiki-default-font-style);font-weight: var(--shiki-default-font-weight);text-decoration: var(--shiki-default-text-decoration);}html .dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html.dark .shiki span {color: var(--shiki-dark);background: var(--shiki-dark-bg);font-style: var(--shiki-dark-font-style);font-weight: var(--shiki-dark-font-weight);text-decoration: var(--shiki-dark-text-decoration);}html pre.shiki code .s8jYJ, html code.shiki .s8jYJ{--shiki-light:#D73A49;--shiki-default:#D73A49;--shiki-dark:#F97583}html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}html pre.shiki code .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sovSZ, html code.shiki .sovSZ{--shiki-light:#22863A;--shiki-default:#22863A;--shiki-dark:#85E89D}html pre.shiki code .sP4rz, html code.shiki .sP4rz{--shiki-light:#E36209;--shiki-default:#E36209;--shiki-dark:#FFAB70}",{"title":11,"searchDepth":1010,"depth":1010,"links":3537},[3538,3539,3540,3541,3545,3554,3555,3556,3557,3558],{"id":894,"depth":1010,"text":894},{"id":909,"depth":1010,"text":909},{"id":978,"depth":1010,"text":978},{"id":1316,"depth":1010,"text":1316,"children":3542},[3543,3544],{"id":1320,"depth":1017,"text":1321},{"id":1530,"depth":1017,"text":1531},{"id":1724,"depth":1010,"text":1390,"children":3546},[3547,3548,3549,3550,3551,3552,3553],{"id":1733,"depth":1017,"text":1734},{"id":1960,"depth":1017,"text":1961},{"id":2006,"depth":1017,"text":2007},{"id":2050,"depth":1017,"text":2051},{"id":2114,"depth":1017,"text":2115},{"id":2198,"depth":1017,"text":2199},{"id":2235,"depth":1017,"text":2236},{"id":2293,"depth":1010,"text":2294},{"id":2328,"depth":1010,"text":2328},{"id":2434,"depth":1010,"text":2434},{"id":2643,"depth":1010,"text":2643},{"id":2910,"depth":1010,"text":2910},"md",{},{"title":837,"description":11},"tutorials\u002Ffront-end\u002Fvue3\u002Frouter","cOo2vst_HQSgFOzaEdNQe1wCgfI1Q4r3SeorGHzEjcQ",1775496421254]