[{"data":1,"prerenderedAt":2973},["ShallowReactive",2],{"search-docs":3,"doc-\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar":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":840,"body":888,"description":11,"extension":2968,"meta":2969,"navigation":1019,"path":839,"seo":2970,"stem":2971,"__hash__":2972},"docs\u002Ftutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar.md",{"type":889,"value":890,"toc":2958},"minimark",[891,895,899,903,944,2954],[892,893,894],"h2",{"id":894},"指令",[896,897,898],"h3",{"id":898},"v-bind",[900,901,902],"p",{},"v-bind 用于将 Vue 中的数据绑定到 HTML 元素的属性上。",[904,905,909],"pre",{"className":906,"code":907,"language":908,"meta":11,"style":11},"language-html shiki shiki-themes github-light github-light github-dark","\u003Cdiv v-bind:id=\"id\">\u003C\u002Fdiv>\n","html",[910,911,912],"code",{"__ignoreMap":11},[913,914,917,921,925,929,932,936,939,941],"span",{"class":915,"line":916},"line",1,[913,918,920],{"class":919},"sxrX7","\u003C",[913,922,924],{"class":923},"sovSZ","div",[913,926,928],{"class":927},"snPdu"," v-bind:id",[913,930,931],{"class":919},"=",[913,933,935],{"class":934},"sIIMD","\"id\"",[913,937,938],{"class":919},">\u003C\u002F",[913,940,924],{"class":923},[913,942,943],{"class":919},">\n",[945,946,948,949,956,1064,1067,1070,1073,1076,1205,1208,1211,1388,1391,1394,1521,1524,1527,1534,1710,1715,1764,1769,1818,1823,1872,1877,1926,1929,1932,2041],"note",{"title":947},"v-bind 简写","\n因为 v-bind 在实际的开发中非常常用，Vue 中提供了特定的简单语法，可以省略 v-bind 仅保留 `:` 来实现绑定。\n",[900,950,951,952,955],{},"值得一说的是，当你要绑定的属性值变量和属性名称相同时，可直接使用 ",[910,953,954],{},":"," 来进行简化绑定。具体实例请看下文。",[904,957,959],{"className":906,"code":958,"language":908,"meta":11,"style":11},"\u003Cdiv v-bind:id=\"id\">\u003C\u002Fdiv>\n\u003Cdiv :id=\"id\">\u003C\u002Fdiv>\n\u003Cdiv :id>\u003C\u002Fdiv>\n\n\u003Cbutton v-bind:disabled=\"isButtonDisabled\">按钮\u003C\u002Fbutton>\n\u003Cbutton :disabled=\"isButtonDisabled\">按钮\u003C\u002Fbutton>\n",[910,960,961,979,999,1014,1021,1044],{"__ignoreMap":11},[913,962,963,965,967,969,971,973,975,977],{"class":915,"line":916},[913,964,920],{"class":919},[913,966,924],{"class":923},[913,968,928],{"class":927},[913,970,931],{"class":919},[913,972,935],{"class":934},[913,974,938],{"class":919},[913,976,924],{"class":923},[913,978,943],{"class":919},[913,980,982,984,986,989,991,993,995,997],{"class":915,"line":981},2,[913,983,920],{"class":919},[913,985,924],{"class":923},[913,987,988],{"class":927}," :id",[913,990,931],{"class":919},[913,992,935],{"class":934},[913,994,938],{"class":919},[913,996,924],{"class":923},[913,998,943],{"class":919},[913,1000,1002,1004,1006,1008,1010,1012],{"class":915,"line":1001},3,[913,1003,920],{"class":919},[913,1005,924],{"class":923},[913,1007,988],{"class":927},[913,1009,938],{"class":919},[913,1011,924],{"class":923},[913,1013,943],{"class":919},[913,1015,1017],{"class":915,"line":1016},4,[913,1018,1020],{"emptyLinePlaceholder":1019},true,"\n",[913,1022,1024,1026,1029,1032,1034,1037,1040,1042],{"class":915,"line":1023},5,[913,1025,920],{"class":919},[913,1027,1028],{"class":923},"button",[913,1030,1031],{"class":927}," v-bind:disabled",[913,1033,931],{"class":919},[913,1035,1036],{"class":934},"\"isButtonDisabled\"",[913,1038,1039],{"class":919},">按钮\u003C\u002F",[913,1041,1028],{"class":923},[913,1043,943],{"class":919},[913,1045,1047,1049,1051,1054,1056,1058,1060,1062],{"class":915,"line":1046},6,[913,1048,920],{"class":919},[913,1050,1028],{"class":923},[913,1052,1053],{"class":927}," :disabled",[913,1055,931],{"class":919},[913,1057,1036],{"class":934},[913,1059,1039],{"class":919},[913,1061,1028],{"class":923},[913,1063,943],{"class":919},[900,1065,1066],{},"不同写法的绑定经过 Vue 处理后，在浏览器渲染出来的效果是完全一致的，不必担心兼容性和运行效率，选择你喜欢的方式即可。\n",[896,1068,1069],{"id":1069},"v-model",[900,1071,1072],{},"v-model 与 v-bind 类似都是将 Vue 中数据和 HTML 中进行绑定，但是 v-bind 是单向绑定，将 Vue 数据绑定到页面，Vue 中数据变化时，页面会跟着变化，但是页面变化，并不会更新 Vue 中数据。",[900,1074,1075],{},"v-model 则将页面和 Vue 中数据双向绑定，无论哪个发生变化，对应一方都会发生改变，通常使用在输入框中。",[904,1077,1081],{"className":1078,"code":1079,"language":1080,"meta":11,"style":11},"language-vue shiki shiki-themes github-light github-light github-dark","\u003Ctemplate>\n    \u003Cinput type=\"text\" v-model=\"message\" \u002F>\n    \u003Cp> {{ message }}\u003C\u002Fp>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup>\nimport { ref } from 'vue'\nvar message = ref(\"CoderMast\");\n\u003C\u002Fscript>\n","vue",[910,1082,1083,1092,1119,1132,1141,1145,1157,1173,1196],{"__ignoreMap":11},[913,1084,1085,1087,1090],{"class":915,"line":916},[913,1086,920],{"class":919},[913,1088,1089],{"class":923},"template",[913,1091,943],{"class":919},[913,1093,1094,1097,1100,1103,1105,1108,1111,1113,1116],{"class":915,"line":981},[913,1095,1096],{"class":919},"    \u003C",[913,1098,1099],{"class":923},"input",[913,1101,1102],{"class":927}," type",[913,1104,931],{"class":919},[913,1106,1107],{"class":934},"\"text\"",[913,1109,1110],{"class":927}," v-model",[913,1112,931],{"class":919},[913,1114,1115],{"class":934},"\"message\"",[913,1117,1118],{"class":919}," \u002F>\n",[913,1120,1121,1123,1125,1128,1130],{"class":915,"line":1001},[913,1122,1096],{"class":919},[913,1124,900],{"class":923},[913,1126,1127],{"class":919},"> {{ message }}\u003C\u002F",[913,1129,900],{"class":923},[913,1131,943],{"class":919},[913,1133,1134,1137,1139],{"class":915,"line":1016},[913,1135,1136],{"class":919},"\u003C\u002F",[913,1138,1089],{"class":923},[913,1140,943],{"class":919},[913,1142,1143],{"class":915,"line":1023},[913,1144,1020],{"emptyLinePlaceholder":1019},[913,1146,1147,1149,1152,1155],{"class":915,"line":1046},[913,1148,920],{"class":919},[913,1150,1151],{"class":923},"script",[913,1153,1154],{"class":927}," setup",[913,1156,943],{"class":919},[913,1158,1160,1164,1167,1170],{"class":915,"line":1159},7,[913,1161,1163],{"class":1162},"s8jYJ","import",[913,1165,1166],{"class":919}," { ref } ",[913,1168,1169],{"class":1162},"from",[913,1171,1172],{"class":934}," 'vue'\n",[913,1174,1176,1179,1182,1184,1187,1190,1193],{"class":915,"line":1175},8,[913,1177,1178],{"class":1162},"var",[913,1180,1181],{"class":919}," message ",[913,1183,931],{"class":1162},[913,1185,1186],{"class":927}," ref",[913,1188,1189],{"class":919},"(",[913,1191,1192],{"class":934},"\"CoderMast\"",[913,1194,1195],{"class":919},");\n",[913,1197,1199,1201,1203],{"class":915,"line":1198},9,[913,1200,1136],{"class":919},[913,1202,1151],{"class":923},[913,1204,943],{"class":919},[896,1206,1207],{"id":1207},"v-on",[900,1209,1210],{},"用于在 HTML 元素上绑定事件监听器，使其能够触发 Vue 实例中的方法或函数。",[904,1212,1214],{"className":1078,"code":1213,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n    \u003Cinput type=\"text\" v-model=\"message\" \u002F>\n    \u003Cp> {{ message }}\u003C\u002Fp>\n    \u003Cbutton v-on:click=\"seeHello\">说你好\u003C\u002Fbutton>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup>\nimport { ref } from 'vue'\nvar message = ref(\"CoderMast\");\n\nfunction seeHello(){\n    message.value = message.value + \" Hello!\";\n    console.log(message.value);\n}\n\u003C\u002Fscript>\n",[910,1215,1216,1224,1244,1256,1277,1285,1289,1299,1309,1325,1330,1342,1362,1373,1379],{"__ignoreMap":11},[913,1217,1218,1220,1222],{"class":915,"line":916},[913,1219,920],{"class":919},[913,1221,1089],{"class":923},[913,1223,943],{"class":919},[913,1225,1226,1228,1230,1232,1234,1236,1238,1240,1242],{"class":915,"line":981},[913,1227,1096],{"class":919},[913,1229,1099],{"class":923},[913,1231,1102],{"class":927},[913,1233,931],{"class":919},[913,1235,1107],{"class":934},[913,1237,1110],{"class":927},[913,1239,931],{"class":919},[913,1241,1115],{"class":934},[913,1243,1118],{"class":919},[913,1245,1246,1248,1250,1252,1254],{"class":915,"line":1001},[913,1247,1096],{"class":919},[913,1249,900],{"class":923},[913,1251,1127],{"class":919},[913,1253,900],{"class":923},[913,1255,943],{"class":919},[913,1257,1258,1260,1262,1265,1267,1270,1273,1275],{"class":915,"line":1016},[913,1259,1096],{"class":919},[913,1261,1028],{"class":923},[913,1263,1264],{"class":927}," v-on:click",[913,1266,931],{"class":919},[913,1268,1269],{"class":934},"\"seeHello\"",[913,1271,1272],{"class":919},">说你好\u003C\u002F",[913,1274,1028],{"class":923},[913,1276,943],{"class":919},[913,1278,1279,1281,1283],{"class":915,"line":1023},[913,1280,1136],{"class":919},[913,1282,1089],{"class":923},[913,1284,943],{"class":919},[913,1286,1287],{"class":915,"line":1046},[913,1288,1020],{"emptyLinePlaceholder":1019},[913,1290,1291,1293,1295,1297],{"class":915,"line":1159},[913,1292,920],{"class":919},[913,1294,1151],{"class":923},[913,1296,1154],{"class":927},[913,1298,943],{"class":919},[913,1300,1301,1303,1305,1307],{"class":915,"line":1175},[913,1302,1163],{"class":1162},[913,1304,1166],{"class":919},[913,1306,1169],{"class":1162},[913,1308,1172],{"class":934},[913,1310,1311,1313,1315,1317,1319,1321,1323],{"class":915,"line":1198},[913,1312,1178],{"class":1162},[913,1314,1181],{"class":919},[913,1316,931],{"class":1162},[913,1318,1186],{"class":927},[913,1320,1189],{"class":919},[913,1322,1192],{"class":934},[913,1324,1195],{"class":919},[913,1326,1328],{"class":915,"line":1327},10,[913,1329,1020],{"emptyLinePlaceholder":1019},[913,1331,1333,1336,1339],{"class":915,"line":1332},11,[913,1334,1335],{"class":1162},"function",[913,1337,1338],{"class":927}," seeHello",[913,1340,1341],{"class":919},"(){\n",[913,1343,1345,1348,1350,1353,1356,1359],{"class":915,"line":1344},12,[913,1346,1347],{"class":919},"    message.value ",[913,1349,931],{"class":1162},[913,1351,1352],{"class":919}," message.value ",[913,1354,1355],{"class":1162},"+",[913,1357,1358],{"class":934}," \" Hello!\"",[913,1360,1361],{"class":919},";\n",[913,1363,1365,1368,1370],{"class":915,"line":1364},13,[913,1366,1367],{"class":919},"    console.",[913,1369,260],{"class":927},[913,1371,1372],{"class":919},"(message.value);\n",[913,1374,1376],{"class":915,"line":1375},14,[913,1377,1378],{"class":919},"}\n",[913,1380,1382,1384,1386],{"class":915,"line":1381},15,[913,1383,1136],{"class":919},[913,1385,1151],{"class":923},[913,1387,943],{"class":919},[896,1389,1390],{"id":1390},"v-if",[900,1392,1393],{},"这个就很简单了，和 if ... else if ... else 语句是相同的功能，只不过这个是在 Vue 文件中进行渲染的。",[904,1395,1397],{"className":1078,"code":1396,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n    \u003Cp v-if=\"showMessage\">Hello {{ name }}!\u003C\u002Fp>\n    \u003Cp v-else>Bye {{ name }}!\u003C\u002Fp>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup>\nimport { ref } from 'vue'\nvar showMessage = ref(true)\nvar name = ref(\"CoderMast\");\n\u003C\u002Fscript>\n",[910,1398,1399,1407,1428,1444,1452,1456,1466,1476,1496,1513],{"__ignoreMap":11},[913,1400,1401,1403,1405],{"class":915,"line":916},[913,1402,920],{"class":919},[913,1404,1089],{"class":923},[913,1406,943],{"class":919},[913,1408,1409,1411,1413,1416,1418,1421,1424,1426],{"class":915,"line":981},[913,1410,1096],{"class":919},[913,1412,900],{"class":923},[913,1414,1415],{"class":927}," v-if",[913,1417,931],{"class":919},[913,1419,1420],{"class":934},"\"showMessage\"",[913,1422,1423],{"class":919},">Hello {{ name }}!\u003C\u002F",[913,1425,900],{"class":923},[913,1427,943],{"class":919},[913,1429,1430,1432,1434,1437,1440,1442],{"class":915,"line":1001},[913,1431,1096],{"class":919},[913,1433,900],{"class":923},[913,1435,1436],{"class":927}," v-else",[913,1438,1439],{"class":919},">Bye {{ name }}!\u003C\u002F",[913,1441,900],{"class":923},[913,1443,943],{"class":919},[913,1445,1446,1448,1450],{"class":915,"line":1016},[913,1447,1136],{"class":919},[913,1449,1089],{"class":923},[913,1451,943],{"class":919},[913,1453,1454],{"class":915,"line":1023},[913,1455,1020],{"emptyLinePlaceholder":1019},[913,1457,1458,1460,1462,1464],{"class":915,"line":1046},[913,1459,920],{"class":919},[913,1461,1151],{"class":923},[913,1463,1154],{"class":927},[913,1465,943],{"class":919},[913,1467,1468,1470,1472,1474],{"class":915,"line":1159},[913,1469,1163],{"class":1162},[913,1471,1166],{"class":919},[913,1473,1169],{"class":1162},[913,1475,1172],{"class":934},[913,1477,1478,1480,1483,1485,1487,1489,1493],{"class":915,"line":1175},[913,1479,1178],{"class":1162},[913,1481,1482],{"class":919}," showMessage ",[913,1484,931],{"class":1162},[913,1486,1186],{"class":927},[913,1488,1189],{"class":919},[913,1490,1492],{"class":1491},"sBjJW","true",[913,1494,1495],{"class":919},")\n",[913,1497,1498,1500,1503,1505,1507,1509,1511],{"class":915,"line":1198},[913,1499,1178],{"class":1162},[913,1501,1502],{"class":919}," name ",[913,1504,931],{"class":1162},[913,1506,1186],{"class":927},[913,1508,1189],{"class":919},[913,1510,1192],{"class":934},[913,1512,1195],{"class":919},[913,1514,1515,1517,1519],{"class":915,"line":1327},[913,1516,1136],{"class":919},[913,1518,1151],{"class":923},[913,1520,943],{"class":919},[896,1522,1523],{"id":1523},"v-for",[900,1525,1526],{},"用于根据数组或对象的属性值来循环渲染元素或组件。",[1528,1529,1530],"ol",{},[1531,1532,1533],"li",{},"遍历数组内容",[904,1535,1537],{"className":1078,"code":1536,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n  \u003Cul>\n    \u003Cli v-for=\"item in items\" :key=\"item.id\">\n      {{ item.text }}\n    \u003C\u002Fli>\n  \u003C\u002Ful>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup>\nimport { ref } from 'vue'\nvar items = ref([\n        { id: 1, text: 'Item 1' },\n        { id: 2, text: 'Item 2' },\n        { id: 3, text: 'Item 3' }\n      ])\n\u003C\u002Fscript>\n",[910,1538,1539,1547,1557,1581,1586,1595,1604,1612,1616,1626,1636,1650,1667,1681,1696,1701],{"__ignoreMap":11},[913,1540,1541,1543,1545],{"class":915,"line":916},[913,1542,920],{"class":919},[913,1544,1089],{"class":923},[913,1546,943],{"class":919},[913,1548,1549,1552,1555],{"class":915,"line":981},[913,1550,1551],{"class":919},"  \u003C",[913,1553,1554],{"class":923},"ul",[913,1556,943],{"class":919},[913,1558,1559,1561,1563,1566,1568,1571,1574,1576,1579],{"class":915,"line":1001},[913,1560,1096],{"class":919},[913,1562,1531],{"class":923},[913,1564,1565],{"class":927}," v-for",[913,1567,931],{"class":919},[913,1569,1570],{"class":934},"\"item in items\"",[913,1572,1573],{"class":927}," :key",[913,1575,931],{"class":919},[913,1577,1578],{"class":934},"\"item.id\"",[913,1580,943],{"class":919},[913,1582,1583],{"class":915,"line":1016},[913,1584,1585],{"class":919},"      {{ item.text }}\n",[913,1587,1588,1591,1593],{"class":915,"line":1023},[913,1589,1590],{"class":919},"    \u003C\u002F",[913,1592,1531],{"class":923},[913,1594,943],{"class":919},[913,1596,1597,1600,1602],{"class":915,"line":1046},[913,1598,1599],{"class":919},"  \u003C\u002F",[913,1601,1554],{"class":923},[913,1603,943],{"class":919},[913,1605,1606,1608,1610],{"class":915,"line":1159},[913,1607,1136],{"class":919},[913,1609,1089],{"class":923},[913,1611,943],{"class":919},[913,1613,1614],{"class":915,"line":1175},[913,1615,1020],{"emptyLinePlaceholder":1019},[913,1617,1618,1620,1622,1624],{"class":915,"line":1198},[913,1619,920],{"class":919},[913,1621,1151],{"class":923},[913,1623,1154],{"class":927},[913,1625,943],{"class":919},[913,1627,1628,1630,1632,1634],{"class":915,"line":1327},[913,1629,1163],{"class":1162},[913,1631,1166],{"class":919},[913,1633,1169],{"class":1162},[913,1635,1172],{"class":934},[913,1637,1638,1640,1643,1645,1647],{"class":915,"line":1332},[913,1639,1178],{"class":1162},[913,1641,1642],{"class":919}," items ",[913,1644,931],{"class":1162},[913,1646,1186],{"class":927},[913,1648,1649],{"class":919},"([\n",[913,1651,1652,1655,1658,1661,1664],{"class":915,"line":1344},[913,1653,1654],{"class":919},"        { id: ",[913,1656,1657],{"class":1491},"1",[913,1659,1660],{"class":919},", text: ",[913,1662,1663],{"class":934},"'Item 1'",[913,1665,1666],{"class":919}," },\n",[913,1668,1669,1671,1674,1676,1679],{"class":915,"line":1364},[913,1670,1654],{"class":919},[913,1672,1673],{"class":1491},"2",[913,1675,1660],{"class":919},[913,1677,1678],{"class":934},"'Item 2'",[913,1680,1666],{"class":919},[913,1682,1683,1685,1688,1690,1693],{"class":915,"line":1375},[913,1684,1654],{"class":919},[913,1686,1687],{"class":1491},"3",[913,1689,1660],{"class":919},[913,1691,1692],{"class":934},"'Item 3'",[913,1694,1695],{"class":919}," }\n",[913,1697,1698],{"class":915,"line":1381},[913,1699,1700],{"class":919},"      ])\n",[913,1702,1704,1706,1708],{"class":915,"line":1703},16,[913,1705,1136],{"class":919},[913,1707,1151],{"class":923},[913,1709,943],{"class":919},[1528,1711,1712],{"start":981},[1531,1713,1714],{},"v-for 还支持第二个参数，参数值为当前项的索引下标：",[904,1716,1718],{"className":906,"code":1717,"language":908,"meta":11,"style":11},"\u003Col>\n    \u003Cli v-for=\"(site, index) in sites\">\n        {{ index }} -{{ site.text }}\n    \u003C\u002Fli>\n\u003C\u002Fol>\n",[910,1719,1720,1728,1743,1748,1756],{"__ignoreMap":11},[913,1721,1722,1724,1726],{"class":915,"line":916},[913,1723,920],{"class":919},[913,1725,1528],{"class":923},[913,1727,943],{"class":919},[913,1729,1730,1732,1734,1736,1738,1741],{"class":915,"line":981},[913,1731,1096],{"class":919},[913,1733,1531],{"class":923},[913,1735,1565],{"class":927},[913,1737,931],{"class":919},[913,1739,1740],{"class":934},"\"(site, index) in sites\"",[913,1742,943],{"class":919},[913,1744,1745],{"class":915,"line":1001},[913,1746,1747],{"class":919},"        {{ index }} -{{ site.text }}\n",[913,1749,1750,1752,1754],{"class":915,"line":1016},[913,1751,1590],{"class":919},[913,1753,1531],{"class":923},[913,1755,943],{"class":919},[913,1757,1758,1760,1762],{"class":915,"line":1023},[913,1759,1136],{"class":919},[913,1761,1528],{"class":923},[913,1763,943],{"class":919},[1528,1765,1766],{"start":1001},[1531,1767,1768],{},"你也可以提供第二个的参数为键名，以便以遍历 Map 类型的值。",[904,1770,1772],{"className":906,"code":1771,"language":908,"meta":11,"style":11},"\u003Cul>\n    \u003Cli v-for=\"(value, key) in object\">\n        {{ key }} : {{ value }}\n    \u003C\u002Fli>\n\u003C\u002Ful>\n",[910,1773,1774,1782,1797,1802,1810],{"__ignoreMap":11},[913,1775,1776,1778,1780],{"class":915,"line":916},[913,1777,920],{"class":919},[913,1779,1554],{"class":923},[913,1781,943],{"class":919},[913,1783,1784,1786,1788,1790,1792,1795],{"class":915,"line":981},[913,1785,1096],{"class":919},[913,1787,1531],{"class":923},[913,1789,1565],{"class":927},[913,1791,931],{"class":919},[913,1793,1794],{"class":934},"\"(value, key) in object\"",[913,1796,943],{"class":919},[913,1798,1799],{"class":915,"line":1001},[913,1800,1801],{"class":919},"        {{ key }} : {{ value }}\n",[913,1803,1804,1806,1808],{"class":915,"line":1016},[913,1805,1590],{"class":919},[913,1807,1531],{"class":923},[913,1809,943],{"class":919},[913,1811,1812,1814,1816],{"class":915,"line":1023},[913,1813,1136],{"class":919},[913,1815,1554],{"class":923},[913,1817,943],{"class":919},[1528,1819,1820],{"start":1016},[1531,1821,1822],{},"遍历 Map 时，第三个参数为索引。",[904,1824,1826],{"className":906,"code":1825,"language":908,"meta":11,"style":11},"\u003Cul>\n    \u003Cli v-for=\"(value, key, index) in object\">\n        {{ index }}. {{ key }} : {{ value }}\n    \u003C\u002Fli>\n\u003C\u002Ful>\n",[910,1827,1828,1836,1851,1856,1864],{"__ignoreMap":11},[913,1829,1830,1832,1834],{"class":915,"line":916},[913,1831,920],{"class":919},[913,1833,1554],{"class":923},[913,1835,943],{"class":919},[913,1837,1838,1840,1842,1844,1846,1849],{"class":915,"line":981},[913,1839,1096],{"class":919},[913,1841,1531],{"class":923},[913,1843,1565],{"class":927},[913,1845,931],{"class":919},[913,1847,1848],{"class":934},"\"(value, key, index) in object\"",[913,1850,943],{"class":919},[913,1852,1853],{"class":915,"line":1001},[913,1854,1855],{"class":919},"        {{ index }}. {{ key }} : {{ value }}\n",[913,1857,1858,1860,1862],{"class":915,"line":1016},[913,1859,1590],{"class":919},[913,1861,1531],{"class":923},[913,1863,943],{"class":919},[913,1865,1866,1868,1870],{"class":915,"line":1023},[913,1867,1136],{"class":919},[913,1869,1554],{"class":923},[913,1871,943],{"class":919},[1528,1873,1874],{"start":1023},[1531,1875,1876],{},"也可以迭代整数，也可以理解为循环多少次。",[904,1878,1880],{"className":906,"code":1879,"language":908,"meta":11,"style":11},"\u003Cul>\n    \u003Cli v-for=\"n in 10\">\n        {{ n }}\n    \u003C\u002Fli>\n\u003C\u002Ful>\n",[910,1881,1882,1890,1905,1910,1918],{"__ignoreMap":11},[913,1883,1884,1886,1888],{"class":915,"line":916},[913,1885,920],{"class":919},[913,1887,1554],{"class":923},[913,1889,943],{"class":919},[913,1891,1892,1894,1896,1898,1900,1903],{"class":915,"line":981},[913,1893,1096],{"class":919},[913,1895,1531],{"class":923},[913,1897,1565],{"class":927},[913,1899,931],{"class":919},[913,1901,1902],{"class":934},"\"n in 10\"",[913,1904,943],{"class":919},[913,1906,1907],{"class":915,"line":1001},[913,1908,1909],{"class":919},"        {{ n }}\n",[913,1911,1912,1914,1916],{"class":915,"line":1016},[913,1913,1590],{"class":919},[913,1915,1531],{"class":923},[913,1917,943],{"class":919},[913,1919,1920,1922,1924],{"class":915,"line":1023},[913,1921,1136],{"class":919},[913,1923,1554],{"class":923},[913,1925,943],{"class":919},[896,1927,1928],{"id":1928},"v-show",[900,1930,1931],{},"v-show 是 Vue.js 提供的一种指令，用于根据表达式的值来条件性地显示或隐藏元素。",[904,1933,1935],{"className":1078,"code":1934,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n    \u003Cbutton v-on:click=\"showMessage = !showMessage\">显示\u002F隐藏\u003C\u002Fbutton>\n    \u003Cp v-show=\"showMessage\">Hello CoderMast!\u003C\u002Fp>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup>\nimport { ref } from 'vue'\nvar showMessage = ref(true)\n\u003C\u002Fscript>\n",[910,1936,1937,1945,1965,1985,1993,1997,2007,2017,2033],{"__ignoreMap":11},[913,1938,1939,1941,1943],{"class":915,"line":916},[913,1940,920],{"class":919},[913,1942,1089],{"class":923},[913,1944,943],{"class":919},[913,1946,1947,1949,1951,1953,1955,1958,1961,1963],{"class":915,"line":981},[913,1948,1096],{"class":919},[913,1950,1028],{"class":923},[913,1952,1264],{"class":927},[913,1954,931],{"class":919},[913,1956,1957],{"class":934},"\"showMessage = !showMessage\"",[913,1959,1960],{"class":919},">显示\u002F隐藏\u003C\u002F",[913,1962,1028],{"class":923},[913,1964,943],{"class":919},[913,1966,1967,1969,1971,1974,1976,1978,1981,1983],{"class":915,"line":1001},[913,1968,1096],{"class":919},[913,1970,900],{"class":923},[913,1972,1973],{"class":927}," v-show",[913,1975,931],{"class":919},[913,1977,1420],{"class":934},[913,1979,1980],{"class":919},">Hello CoderMast!\u003C\u002F",[913,1982,900],{"class":923},[913,1984,943],{"class":919},[913,1986,1987,1989,1991],{"class":915,"line":1016},[913,1988,1136],{"class":919},[913,1990,1089],{"class":923},[913,1992,943],{"class":919},[913,1994,1995],{"class":915,"line":1023},[913,1996,1020],{"emptyLinePlaceholder":1019},[913,1998,1999,2001,2003,2005],{"class":915,"line":1046},[913,2000,920],{"class":919},[913,2002,1151],{"class":923},[913,2004,1154],{"class":927},[913,2006,943],{"class":919},[913,2008,2009,2011,2013,2015],{"class":915,"line":1159},[913,2010,1163],{"class":1162},[913,2012,1166],{"class":919},[913,2014,1169],{"class":1162},[913,2016,1172],{"class":934},[913,2018,2019,2021,2023,2025,2027,2029,2031],{"class":915,"line":1175},[913,2020,1178],{"class":1162},[913,2022,1482],{"class":919},[913,2024,931],{"class":1162},[913,2026,1186],{"class":927},[913,2028,1189],{"class":919},[913,2030,1492],{"class":1491},[913,2032,1495],{"class":919},[913,2034,2035,2037,2039],{"class":915,"line":1198},[913,2036,1136],{"class":919},[913,2038,1151],{"class":923},[913,2040,943],{"class":919},[2042,2043,2045,2046,2059,2062,2065,2068,2073,2076,2094,2099,2102,2149,2152,2155,2158,2161,2168,2192,2195,2218,2221,2224,2461,2464,2478,2504,2508,2511,2514,2517,2520,2689,2695,2698,2702,2705,2708,2868,2871,2874],"warning",{"title":2044},"v-show 和 v-bind:disabled 有什么区别？","\n1. v-show 是用于根据条件控制元素的显示与隐藏的指令。\n    - 当表达式为真时，元素会显示；当表达式为假时，元素会隐藏。它通过修改元素的 display CSS 属性来实现这一点。\n    - 即使元素被隐藏，它仍然存在于 DOM 中，只是不可见。\n    - 适用于需要频繁切换显示与隐藏的情况，因为元素的状态保持不变，只是修改了显示方式。\n",[1528,2047,2048],{"start":981},[1531,2049,2050,2051],{},"v-bind:disabled 用于将元素的禁用状态绑定到一个表达式。\n",[1554,2052,2053,2056],{},[1531,2054,2055],{},"当表达式的值为真时，元素会被禁用；当表达式的值为假时，元素会处于可用状态。",[1531,2057,2058],{},"通常用于表单元素（如按钮、输入框等），以根据特定条件禁用或启用它们。",[900,2060,2061],{},"因此，v-show 用于控制元素的显示与隐藏，而 v-bind:disabled 用于控制元素的禁用状态。根据具体的需求，你可以选择使用其中的一个或两者结合使用。\n",[892,2063,2064],{"id":2064},"模板语法",[896,2066,2067],{"id":2067},"插值",[1554,2069,2070],{},[1531,2071,2072],{},"普通文本",[900,2074,2075],{},"Vue 组件中可直接使用双大括号来进行渲染，调用的对象可以是变量，也可以是计算属性。",[904,2077,2079],{"className":1078,"code":2078,"language":1080,"meta":11,"style":11},"\u003Cspan>Message: {{ msg }}\u003C\u002Fspan>\n",[910,2080,2081],{"__ignoreMap":11},[913,2082,2083,2085,2087,2090,2092],{"class":915,"line":916},[913,2084,920],{"class":919},[913,2086,913],{"class":923},[913,2088,2089],{"class":919},">Message: {{ msg }}\u003C\u002F",[913,2091,913],{"class":923},[913,2093,943],{"class":919},[1554,2095,2096],{},[1531,2097,2098],{},"HTML文本",[900,2100,2101],{},"双大括号会将数据解释为纯文本，而不是 HTML。若想插入 HTML，你需要使用 v-html 指令：",[904,2103,2105],{"className":906,"code":2104,"language":908,"meta":11,"style":11},"\u003Cp>Using text interpolation: {{ rawHtml }}\u003C\u002Fp>\n\u003Cp>Using v-html directive: \u003Cspan v-html=\"rawHtml\">\u003C\u002Fspan>\u003C\u002Fp>\n",[910,2106,2107,2120],{"__ignoreMap":11},[913,2108,2109,2111,2113,2116,2118],{"class":915,"line":916},[913,2110,920],{"class":919},[913,2112,900],{"class":923},[913,2114,2115],{"class":919},">Using text interpolation: {{ rawHtml }}\u003C\u002F",[913,2117,900],{"class":923},[913,2119,943],{"class":919},[913,2121,2122,2124,2126,2129,2131,2134,2136,2139,2141,2143,2145,2147],{"class":915,"line":981},[913,2123,920],{"class":919},[913,2125,900],{"class":923},[913,2127,2128],{"class":919},">Using v-html directive: \u003C",[913,2130,913],{"class":923},[913,2132,2133],{"class":927}," v-html",[913,2135,931],{"class":919},[913,2137,2138],{"class":934},"\"rawHtml\"",[913,2140,938],{"class":919},[913,2142,913],{"class":923},[913,2144,938],{"class":919},[913,2146,900],{"class":923},[913,2148,943],{"class":919},[900,2150,2151],{},"Using text interpolation: \u003Cspan style=\"color: red\">This should be red.\u003C\u002Fspan\u003C\u002Fp>",[900,2153,2154],{},"Using v-html directive: \u003Cspan style=\"color: red\">This should be red.\u003C\u002Fspan>",[945,2156],{"title":2157},"这里使用到的就是在上一个章节学习的指令概念，v-html 指令，使用简单易懂，不必担心。",[896,2159,2160],{"id":2160},"属性",[900,2162,2163,2164,2167],{},"如果要对 HTML 标签中的属性值进行绑定，不能直接使用 ",[910,2165,2166],{},"{{ }}","，需要使用 v-bind 指令，用来响应式的绑定一个属性值。",[904,2169,2171],{"className":906,"code":2170,"language":908,"meta":11,"style":11},"\u003Cdiv v-bind:id=\"dynamicId\">\u003C\u002Fdiv>\n",[910,2172,2173],{"__ignoreMap":11},[913,2174,2175,2177,2179,2181,2183,2186,2188,2190],{"class":915,"line":916},[913,2176,920],{"class":919},[913,2178,924],{"class":923},[913,2180,928],{"class":927},[913,2182,931],{"class":919},[913,2184,2185],{"class":934},"\"dynamicId\"",[913,2187,938],{"class":919},[913,2189,924],{"class":923},[913,2191,943],{"class":919},[900,2193,2194],{},"对于布尔值 boolean 属性，常规值为 true 或者 false，如果属性值为 null 或者 undefined，则该属性不会显示出来。",[904,2196,2198],{"className":906,"code":2197,"language":908,"meta":11,"style":11},"\u003Cbutton v-bind:disabled=\"isButtonDisabled\">按钮\u003C\u002Fbutton>\n",[910,2199,2200],{"__ignoreMap":11},[913,2201,2202,2204,2206,2208,2210,2212,2214,2216],{"class":915,"line":916},[913,2203,920],{"class":919},[913,2205,1028],{"class":923},[913,2207,1031],{"class":927},[913,2209,931],{"class":919},[913,2211,1036],{"class":934},[913,2213,1039],{"class":919},[913,2215,1028],{"class":923},[913,2217,943],{"class":919},[896,2219,2220],{"id":2220},"表达式",[900,2222,2223],{},"Vue 提供了完整的 JavaScript 表达式支持，可以直接在模板内使用。",[904,2225,2227],{"className":906,"code":2226,"language":908,"meta":11,"style":11},"\u003Ctemplate>\n    \u003Cdiv id=\"app\">\n        \u003Cp> Hello World {{ 1 + 1 }} 次！\u003C\u002Fp>\n        \u003Cp> {{ ok ? 'YES' : 'NO' }} \u003C\u002Fp>\n\n        \u003Cdiv v-bind:id=\"id\">编程桅杆\u003C\u002Fdiv>\n        \u003C!-- 也可以写成如下格式 -->\n        \u003Cdiv :id=\"id\">编程桅杆\u003C\u002Fdiv>\n        \u003Cdiv :id>编程桅杆\u003C\u002Fdiv>\n\n        \u003C!-- 还可以直接在 {{ }}  内写 JavaScript 代码-->\n        {{  message.value.toLowerCase() }}\n    \u003C\u002Fdiv>\n\u003C\u002Ftemplate>\n\u003Cscript setup>\nimport { ref } from 'vue'\n\nconst ok = ref(true)\nconst message = ref(\"CoderMast!\")\nconst id = ref(1)\n\u003C\u002Fscript>\n",[910,2228,2229,2237,2253,2267,2280,2284,2303,2309,2327,2341,2345,2350,2355,2363,2371,2381,2391,2396,2416,2435,2452],{"__ignoreMap":11},[913,2230,2231,2233,2235],{"class":915,"line":916},[913,2232,920],{"class":919},[913,2234,1089],{"class":923},[913,2236,943],{"class":919},[913,2238,2239,2241,2243,2246,2248,2251],{"class":915,"line":981},[913,2240,1096],{"class":919},[913,2242,924],{"class":923},[913,2244,2245],{"class":927}," id",[913,2247,931],{"class":919},[913,2249,2250],{"class":934},"\"app\"",[913,2252,943],{"class":919},[913,2254,2255,2258,2260,2263,2265],{"class":915,"line":1001},[913,2256,2257],{"class":919},"        \u003C",[913,2259,900],{"class":923},[913,2261,2262],{"class":919},"> Hello World {{ 1 + 1 }} 次！\u003C\u002F",[913,2264,900],{"class":923},[913,2266,943],{"class":919},[913,2268,2269,2271,2273,2276,2278],{"class":915,"line":1016},[913,2270,2257],{"class":919},[913,2272,900],{"class":923},[913,2274,2275],{"class":919},"> {{ ok ? 'YES' : 'NO' }} \u003C\u002F",[913,2277,900],{"class":923},[913,2279,943],{"class":919},[913,2281,2282],{"class":915,"line":1023},[913,2283,1020],{"emptyLinePlaceholder":1019},[913,2285,2286,2288,2290,2292,2294,2296,2299,2301],{"class":915,"line":1046},[913,2287,2257],{"class":919},[913,2289,924],{"class":923},[913,2291,928],{"class":927},[913,2293,931],{"class":919},[913,2295,935],{"class":934},[913,2297,2298],{"class":919},">编程桅杆\u003C\u002F",[913,2300,924],{"class":923},[913,2302,943],{"class":919},[913,2304,2305],{"class":915,"line":1159},[913,2306,2308],{"class":2307},"sCsY4","        \u003C!-- 也可以写成如下格式 -->\n",[913,2310,2311,2313,2315,2317,2319,2321,2323,2325],{"class":915,"line":1175},[913,2312,2257],{"class":919},[913,2314,924],{"class":923},[913,2316,988],{"class":927},[913,2318,931],{"class":919},[913,2320,935],{"class":934},[913,2322,2298],{"class":919},[913,2324,924],{"class":923},[913,2326,943],{"class":919},[913,2328,2329,2331,2333,2335,2337,2339],{"class":915,"line":1198},[913,2330,2257],{"class":919},[913,2332,924],{"class":923},[913,2334,988],{"class":927},[913,2336,2298],{"class":919},[913,2338,924],{"class":923},[913,2340,943],{"class":919},[913,2342,2343],{"class":915,"line":1327},[913,2344,1020],{"emptyLinePlaceholder":1019},[913,2346,2347],{"class":915,"line":1332},[913,2348,2349],{"class":2307},"        \u003C!-- 还可以直接在 {{ }}  内写 JavaScript 代码-->\n",[913,2351,2352],{"class":915,"line":1344},[913,2353,2354],{"class":919},"        {{  message.value.toLowerCase() }}\n",[913,2356,2357,2359,2361],{"class":915,"line":1364},[913,2358,1590],{"class":919},[913,2360,924],{"class":923},[913,2362,943],{"class":919},[913,2364,2365,2367,2369],{"class":915,"line":1375},[913,2366,1136],{"class":919},[913,2368,1089],{"class":923},[913,2370,943],{"class":919},[913,2372,2373,2375,2377,2379],{"class":915,"line":1381},[913,2374,920],{"class":919},[913,2376,1151],{"class":923},[913,2378,1154],{"class":927},[913,2380,943],{"class":919},[913,2382,2383,2385,2387,2389],{"class":915,"line":1703},[913,2384,1163],{"class":1162},[913,2386,1166],{"class":919},[913,2388,1169],{"class":1162},[913,2390,1172],{"class":934},[913,2392,2394],{"class":915,"line":2393},17,[913,2395,1020],{"emptyLinePlaceholder":1019},[913,2397,2399,2402,2405,2408,2410,2412,2414],{"class":915,"line":2398},18,[913,2400,2401],{"class":1162},"const",[913,2403,2404],{"class":1491}," ok",[913,2406,2407],{"class":1162}," =",[913,2409,1186],{"class":927},[913,2411,1189],{"class":919},[913,2413,1492],{"class":1491},[913,2415,1495],{"class":919},[913,2417,2419,2421,2424,2426,2428,2430,2433],{"class":915,"line":2418},19,[913,2420,2401],{"class":1162},[913,2422,2423],{"class":1491}," message",[913,2425,2407],{"class":1162},[913,2427,1186],{"class":927},[913,2429,1189],{"class":919},[913,2431,2432],{"class":934},"\"CoderMast!\"",[913,2434,1495],{"class":919},[913,2436,2438,2440,2442,2444,2446,2448,2450],{"class":915,"line":2437},20,[913,2439,2401],{"class":1162},[913,2441,2245],{"class":1491},[913,2443,2407],{"class":1162},[913,2445,1186],{"class":927},[913,2447,1189],{"class":919},[913,2449,1657],{"class":1491},[913,2451,1495],{"class":919},[913,2453,2455,2457,2459],{"class":915,"line":2454},21,[913,2456,1136],{"class":919},[913,2458,1151],{"class":923},[913,2460,943],{"class":919},[896,2462,2463],{"id":2463},"修饰符",[900,2465,2466,2467,2470,2471,2474,2475],{},"修饰符是以半角句号 ",[910,2468,2469],{},"."," 指明的特殊后缀，用于指出一个指令应该以特殊方式绑定。例如，",[910,2472,2473],{},".prevent"," 修饰符告诉 v-on 指令对于触发的事件调用 ",[910,2476,2477],{},"event.preventDefault()",[904,2479,2481],{"className":906,"code":2480,"language":908,"meta":11,"style":11},"\u003Cform v-on:submit.prevent=\"onSubmit\">\u003C\u002Fform>\n",[910,2482,2483],{"__ignoreMap":11},[913,2484,2485,2487,2490,2493,2495,2498,2500,2502],{"class":915,"line":916},[913,2486,920],{"class":919},[913,2488,2489],{"class":923},"form",[913,2491,2492],{"class":927}," v-on:submit.prevent",[913,2494,931],{"class":919},[913,2496,2497],{"class":934},"\"onSubmit\"",[913,2499,938],{"class":919},[913,2501,2489],{"class":923},[913,2503,943],{"class":919},[892,2505,2507],{"id":2506},"ref-属性","Ref 属性",[900,2509,2510],{},"想要获取页面上标签对应的 DOM 信息，通常使用 JS 中的选择器来进行获取，但是由于 Vue 是单页面项目，所有的组件都是挂载在 index.html 中的某个标签上，组件中的命名不免重复，获取指定标签的难度较大。",[900,2512,2513],{},"为了解决这个问题，可以使用标签上的 ref 属性，可以直接获取到标签的 DOM 信息，不必使用 JS 来进行操作。",[896,2515,2516],{"id":2516},"普通标签",[900,2518,2519],{},"使用在普通标签上，获取的是改标签的 DOM 信息。",[904,2521,2523],{"className":1078,"code":2522,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n    \u003Ch1 ref=\"title\">Hello CoderMast！\u003C\u002Fh1>\n    \u003Cbutton @click=\"getTitleInfo\">获取 Title DOM 信息\u003C\u002Fbutton>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup lang=\"ts\">\nimport { ref } from 'vue';\n\n\u002F\u002F 定义 DOM 元素接受变量\nconst title = ref();\n\n\u002F\u002F 获取 Title DOM 信息\nconst getTitleInfo = () => {\n    console.log(title.value);\n}\n\u003C\u002Fscript>\n",[910,2524,2525,2533,2554,2575,2583,2587,2605,2618,2622,2627,2641,2645,2650,2668,2677,2681],{"__ignoreMap":11},[913,2526,2527,2529,2531],{"class":915,"line":916},[913,2528,920],{"class":919},[913,2530,1089],{"class":923},[913,2532,943],{"class":919},[913,2534,2535,2537,2540,2542,2544,2547,2550,2552],{"class":915,"line":981},[913,2536,1096],{"class":919},[913,2538,2539],{"class":923},"h1",[913,2541,1186],{"class":927},[913,2543,931],{"class":919},[913,2545,2546],{"class":934},"\"title\"",[913,2548,2549],{"class":919},">Hello CoderMast！\u003C\u002F",[913,2551,2539],{"class":923},[913,2553,943],{"class":919},[913,2555,2556,2558,2560,2563,2565,2568,2571,2573],{"class":915,"line":1001},[913,2557,1096],{"class":919},[913,2559,1028],{"class":923},[913,2561,2562],{"class":927}," @click",[913,2564,931],{"class":919},[913,2566,2567],{"class":934},"\"getTitleInfo\"",[913,2569,2570],{"class":919},">获取 Title DOM 信息\u003C\u002F",[913,2572,1028],{"class":923},[913,2574,943],{"class":919},[913,2576,2577,2579,2581],{"class":915,"line":1016},[913,2578,1136],{"class":919},[913,2580,1089],{"class":923},[913,2582,943],{"class":919},[913,2584,2585],{"class":915,"line":1023},[913,2586,1020],{"emptyLinePlaceholder":1019},[913,2588,2589,2591,2593,2595,2598,2600,2603],{"class":915,"line":1046},[913,2590,920],{"class":919},[913,2592,1151],{"class":923},[913,2594,1154],{"class":927},[913,2596,2597],{"class":927}," lang",[913,2599,931],{"class":919},[913,2601,2602],{"class":934},"\"ts\"",[913,2604,943],{"class":919},[913,2606,2607,2609,2611,2613,2616],{"class":915,"line":1159},[913,2608,1163],{"class":1162},[913,2610,1166],{"class":919},[913,2612,1169],{"class":1162},[913,2614,2615],{"class":934}," 'vue'",[913,2617,1361],{"class":919},[913,2619,2620],{"class":915,"line":1175},[913,2621,1020],{"emptyLinePlaceholder":1019},[913,2623,2624],{"class":915,"line":1198},[913,2625,2626],{"class":2307},"\u002F\u002F 定义 DOM 元素接受变量\n",[913,2628,2629,2631,2634,2636,2638],{"class":915,"line":1327},[913,2630,2401],{"class":1162},[913,2632,2633],{"class":1491}," title",[913,2635,2407],{"class":1162},[913,2637,1186],{"class":927},[913,2639,2640],{"class":919},"();\n",[913,2642,2643],{"class":915,"line":1332},[913,2644,1020],{"emptyLinePlaceholder":1019},[913,2646,2647],{"class":915,"line":1344},[913,2648,2649],{"class":2307},"\u002F\u002F 获取 Title DOM 信息\n",[913,2651,2652,2654,2657,2659,2662,2665],{"class":915,"line":1364},[913,2653,2401],{"class":1162},[913,2655,2656],{"class":927}," getTitleInfo",[913,2658,2407],{"class":1162},[913,2660,2661],{"class":919}," () ",[913,2663,2664],{"class":1162},"=>",[913,2666,2667],{"class":919}," {\n",[913,2669,2670,2672,2674],{"class":915,"line":1375},[913,2671,1367],{"class":919},[913,2673,260],{"class":927},[913,2675,2676],{"class":919},"(title.value);\n",[913,2678,2679],{"class":915,"line":1381},[913,2680,1378],{"class":919},[913,2682,2683,2685,2687],{"class":915,"line":1703},[913,2684,1136],{"class":919},[913,2686,1151],{"class":923},[913,2688,943],{"class":919},[900,2690,2691,2692],{},"点击该按钮，打印在控制台的信息为：",[910,2693,2694],{},"\u003Ch1>Hello CoderMast！\u003C\u002Fh1>",[900,2696,2697],{},"可以直接拿到这个对象，像我们之前去操作 DOM 元素那样，可以对它进行任何操作。",[945,2699,2701],{"title":2700},"说明","\n在这个案例中，将打印信息写在了方法内，那么不写在方法内直接进行打印呢？答案是打印为空。出现这种现象的主要原因是标签上标注了 setup，setup 函数内执行的内容是早于页面挂载的，当页面还没挂载时，当然获取不到对应的 DOM 信息。\n- [Vue - 生命周期详解](https:\u002F\u002Fwww.codermast.com\u002Ffront-end\u002Fvue3\u002Flife-cycle.html)\n",[896,2703,2704],{"id":2704},"组件标签",[900,2706,2707],{},"使用在组件标签上，获取的是其子组件的信息。",[904,2709,2711],{"className":1078,"code":2710,"language":1080,"meta":11,"style":11},"\u003Ctemplate>\n    \u003CPerson ref=\"person\" \u002F>\n    \u003Cbutton @click=\"getPersonInfo\">获取信息\u003C\u002Fbutton>\n\u003C\u002Ftemplate>\n\n\u003Cscript setup lang=\"ts\">\nimport { ref } from 'vue';\nimport Person from '.\u002Fcomponents\u002FPerson.vue';\n\nconst person = ref();\n\nconst getPersonInfo = () => {\n    console.log(person.value);\n}\n\u003C\u002Fscript>\n",[910,2712,2713,2721,2737,2757,2765,2769,2785,2797,2811,2815,2828,2832,2847,2856,2860],{"__ignoreMap":11},[913,2714,2715,2717,2719],{"class":915,"line":916},[913,2716,920],{"class":919},[913,2718,1089],{"class":923},[913,2720,943],{"class":919},[913,2722,2723,2725,2728,2730,2732,2735],{"class":915,"line":981},[913,2724,1096],{"class":919},[913,2726,2727],{"class":923},"Person",[913,2729,1186],{"class":927},[913,2731,931],{"class":919},[913,2733,2734],{"class":934},"\"person\"",[913,2736,1118],{"class":919},[913,2738,2739,2741,2743,2745,2747,2750,2753,2755],{"class":915,"line":1001},[913,2740,1096],{"class":919},[913,2742,1028],{"class":923},[913,2744,2562],{"class":927},[913,2746,931],{"class":919},[913,2748,2749],{"class":934},"\"getPersonInfo\"",[913,2751,2752],{"class":919},">获取信息\u003C\u002F",[913,2754,1028],{"class":923},[913,2756,943],{"class":919},[913,2758,2759,2761,2763],{"class":915,"line":1016},[913,2760,1136],{"class":919},[913,2762,1089],{"class":923},[913,2764,943],{"class":919},[913,2766,2767],{"class":915,"line":1023},[913,2768,1020],{"emptyLinePlaceholder":1019},[913,2770,2771,2773,2775,2777,2779,2781,2783],{"class":915,"line":1046},[913,2772,920],{"class":919},[913,2774,1151],{"class":923},[913,2776,1154],{"class":927},[913,2778,2597],{"class":927},[913,2780,931],{"class":919},[913,2782,2602],{"class":934},[913,2784,943],{"class":919},[913,2786,2787,2789,2791,2793,2795],{"class":915,"line":1159},[913,2788,1163],{"class":1162},[913,2790,1166],{"class":919},[913,2792,1169],{"class":1162},[913,2794,2615],{"class":934},[913,2796,1361],{"class":919},[913,2798,2799,2801,2804,2806,2809],{"class":915,"line":1175},[913,2800,1163],{"class":1162},[913,2802,2803],{"class":919}," Person ",[913,2805,1169],{"class":1162},[913,2807,2808],{"class":934}," '.\u002Fcomponents\u002FPerson.vue'",[913,2810,1361],{"class":919},[913,2812,2813],{"class":915,"line":1198},[913,2814,1020],{"emptyLinePlaceholder":1019},[913,2816,2817,2819,2822,2824,2826],{"class":915,"line":1327},[913,2818,2401],{"class":1162},[913,2820,2821],{"class":1491}," person",[913,2823,2407],{"class":1162},[913,2825,1186],{"class":927},[913,2827,2640],{"class":919},[913,2829,2830],{"class":915,"line":1332},[913,2831,1020],{"emptyLinePlaceholder":1019},[913,2833,2834,2836,2839,2841,2843,2845],{"class":915,"line":1344},[913,2835,2401],{"class":1162},[913,2837,2838],{"class":927}," getPersonInfo",[913,2840,2407],{"class":1162},[913,2842,2661],{"class":919},[913,2844,2664],{"class":1162},[913,2846,2667],{"class":919},[913,2848,2849,2851,2853],{"class":915,"line":1364},[913,2850,1367],{"class":919},[913,2852,260],{"class":927},[913,2854,2855],{"class":919},"(person.value);\n",[913,2857,2858],{"class":915,"line":1375},[913,2859,1378],{"class":919},[913,2861,2862,2864,2866],{"class":915,"line":1381},[913,2863,1136],{"class":919},[913,2865,1151],{"class":923},[913,2867,943],{"class":919},[900,2869,2870],{},"这里打印出来的信息是子组件中的对象信息，但是该对象中的信息是无法拿到的，需要子组件去配置。",[900,2872,2873],{},"在子组件中需要将数据暴露给外部，这样外部才能获取到对应的信息。",[904,2875,2879],{"className":2876,"code":2877,"language":2878,"meta":11,"style":11},"language-ts shiki shiki-themes github-light github-light github-dark","import {ref,defineExpose} from 'vue'\n\n\u002F\u002F 数据\nlet name = ref('张三')\nlet age = ref(18)\n\n\u002F\u002F 使用 defineExpose 将组件中的数据交给外部\ndefineExpose({ name, age })\n","ts",[910,2880,2881,2892,2896,2901,2919,2937,2941,2946],{"__ignoreMap":11},[913,2882,2883,2885,2888,2890],{"class":915,"line":916},[913,2884,1163],{"class":1162},[913,2886,2887],{"class":919}," {ref,defineExpose} ",[913,2889,1169],{"class":1162},[913,2891,1172],{"class":934},[913,2893,2894],{"class":915,"line":981},[913,2895,1020],{"emptyLinePlaceholder":1019},[913,2897,2898],{"class":915,"line":1001},[913,2899,2900],{"class":2307},"\u002F\u002F 数据\n",[913,2902,2903,2906,2908,2910,2912,2914,2917],{"class":915,"line":1016},[913,2904,2905],{"class":1162},"let",[913,2907,1502],{"class":919},[913,2909,931],{"class":1162},[913,2911,1186],{"class":927},[913,2913,1189],{"class":919},[913,2915,2916],{"class":934},"'张三'",[913,2918,1495],{"class":919},[913,2920,2921,2923,2926,2928,2930,2932,2935],{"class":915,"line":1023},[913,2922,2905],{"class":1162},[913,2924,2925],{"class":919}," age ",[913,2927,931],{"class":1162},[913,2929,1186],{"class":927},[913,2931,1189],{"class":919},[913,2933,2934],{"class":1491},"18",[913,2936,1495],{"class":919},[913,2938,2939],{"class":915,"line":1046},[913,2940,1020],{"emptyLinePlaceholder":1019},[913,2942,2943],{"class":915,"line":1159},[913,2944,2945],{"class":2307},"\u002F\u002F 使用 defineExpose 将组件中的数据交给外部\n",[913,2947,2948,2951],{"class":915,"line":1175},[913,2949,2950],{"class":927},"defineExpose",[913,2952,2953],{"class":919},"({ name, age })\n",[2955,2956,2957],"style",{},"html pre.shiki code .sxrX7, html code.shiki .sxrX7{--shiki-light:#24292E;--shiki-default:#24292E;--shiki-dark:#E1E4E8}html pre.shiki code .sovSZ, html code.shiki .sovSZ{--shiki-light:#22863A;--shiki-default:#22863A;--shiki-dark:#85E89D}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 .sBjJW, html code.shiki .sBjJW{--shiki-light:#005CC5;--shiki-default:#005CC5;--shiki-dark:#79B8FF}html pre.shiki code .sCsY4, html code.shiki .sCsY4{--shiki-light:#6A737D;--shiki-default:#6A737D;--shiki-dark:#6A737D}",{"title":11,"searchDepth":981,"depth":981,"links":2959},[2960],{"id":894,"depth":981,"text":894,"children":2961},[2962,2963,2964,2965,2966,2967],{"id":898,"depth":1001,"text":898},{"id":1069,"depth":1001,"text":1069},{"id":1207,"depth":1001,"text":1207},{"id":1390,"depth":1001,"text":1390},{"id":1523,"depth":1001,"text":1523},{"id":1928,"depth":1001,"text":1928},"md",{},{"title":840,"description":11},"tutorials\u002Ffront-end\u002Fvue3\u002Ftemplate-grammar","MxJgc5nWU7RBIYGhrNW43kpreBjS_1RvuKPRfsK0qTw",1775496420764]