VUE3:封装一个评论回复组件
之前用React封装的评论回复组件,里面有三个主要部分:CommentComponent作为主组件,CommentItem处理单个评论项,CommentInput负责输入框。现在需要将这些转换为Vue3的组件。
Vue3和React在状态管理上有所不同,Vue3使用ref和reactive来管理响应式数据,而React用useState。我需要将React的useState转换为Vue3的ref。比如activeReplyId和comments在React中是使用useState,在Vue3中应该用ref来声明。
接下来,处理组件结构。在Vue3中,通常使用单文件组件(.vue文件),所以需要将每个部分拆分成单独的组件。可能需要将CommentItem和CommentInput作为子组件,或者作为主组件的一部分。不过根据用户的需求,可能需要保持组件的可复用性,所以拆分成单独的组件是合理的。
然后,Props的处理。在React中使用PropTypes,而Vue3中使用defineProps。需要将原来的PropTypes转换为Vue3的props定义。例如,initialComments和currentUser作为props传入,需要在子组件中正确声明。
递归渲染在Vue中如何处理?React中CommentItem递归调用自身,Vue中也需要类似的方式。在Vue的单文件组件中,组件可以在模板中直接引用自己,但需要注意组件名称是否正确注册。可能需要使用name属性来允许递归调用。
另外,事件的处理。在React中,通过props传递回调函数,比如onReply、setActiveReplyId。在Vue中,子组件通过$emit触发事件,父组件监听这些事件。所以需要将原来的回调函数转换为Vue的事件发射机制。例如,当用户点击回复按钮时,CommentItem应该emit一个事件,父组件监听到后更新activeReplyId。
状态提升的问题。在React中,activeReplyId和comments状态提升到主组件,Vue中同样需要将这些状态放在父组件中,通过props传递给子组件,或者使用provide/inject,但props更直接。这里应该保持状态在主组件,通过props传递下去。
输入框组件CommentInput需要处理提交和取消。在React中,通过父组件传递onSubmit和onCancel。在Vue中,子组件应该emit事件,比如submit和cancel,父组件监听并处理。
样式部分,用户之前提供了CSS,现在需要将这些样式转换到Vue的单文件组件中的style标签内。注意scoped属性,避免样式污染。或者用户可能使用CSS预处理器,但用户没有特别说明,所以保持普通CSS。
然后,考虑TypeScript的支持。用户没有明确提到,但Vue3支持TS,所以如果需要,可以添加类型定义。不过用户可能只需要基本的JS实现,所以暂时使用JS。
接下来,实现递归评论项。在Vue中,组件需要能够引用自身,所以需要在组件内部使用name属性,比如name: ‘CommentItem’,然后在模板中使用来递归渲染子评论。
测试一下功能是否完整:多级回复、最大深度限制、显示回复对象、时间生成、当前用户处理。确保在Vue中响应式数据更新正确,比如添加回复后,comments数组的更新会触发视图重新渲染。
最后,示例数据和用法。在Vue中,父组件传入initial-comments和current-user作为props,确保props命名在Vue中使用kebab-case。比如initialComments在props中定义为initial-comments。
可能遇到的陷阱:递归组件的注册,确保组件可以在模板中正确引用自己。另外,在Vue中,直接修改props是不允许的,所以所有状态变更都应该通过父组件的事件来触发,保持单向数据流。
总结步骤:转换React组件结构到Vue3的单文件组件,处理响应式状态,转换事件处理机制,确保递归渲染正常工作,调整样式,提供使用示例和props验证。
以下是基于 Vue 3 封装的评论回复组件实现(使用 Composition API + <script setup>
语法):
<!-- CommentComponent.vue -->
<template><div class="comment-container"><!-- 主评论输入框 --><CommentInput @submit="addComment" /><!-- 评论列表 --><div class="comments-list"><CommentItemv-for="comment in comments":key="comment.id":comment="comment":depth="0":current-user="currentUser":active-reply-id="activeReplyId"@reply="handleReply"@set-active-reply="setActiveReplyId"/></div></div>
</template><script setup>
import { ref } from 'vue'
import CommentItem from './CommentItem.vue'
import CommentInput from './CommentInput.vue'const props = defineProps({initialComments: {type: Array,default: () => []},currentUser: {type: String,default: '匿名用户'}
})const comments = ref([...props.initialComments])
const activeReplyId = ref(null)// 添加新评论/回复
const addComment = (content, parentId = null) => {const newComment = {id: Date.now(),author: props.currentUser,content,time: new Date().toLocaleString(),replies: []}if (!parentId) {comments.value.push(newComment)} else {const updateComments = (items) => items.map(item => {if (item.id === parentId) {return {...item,replies: [...item.replies, newComment]}}return {...item,replies: updateComments(item.replies)}})comments.value = updateComments(comments.value)}
}// 处理回复事件
const handleReply = ({ parentId, content }) => {addComment(content, parentId)activeReplyId.value = null
}const setActiveReplyId = (id) => {activeReplyId.value = id
}
</script><style scoped>
/* 样式与 React 版本保持一致 */
.comment-container {max-width: 800px;margin: 0 auto;padding: 20px;
}
</style>
<!-- CommentItem.vue -->
<template><div class="comment-item":style="{ marginLeft: depth * 32 + 'px' }"><div class="comment-header"><span class="comment-author">{{ comment.author }}</span><span v-if="parentAuthor" class="reply-to">回复 @{{ parentAuthor }}</span><span class="comment-time">{{ comment.time }}</span></div><div class="comment-content">{{ comment.content }}</div><button v-if="canReply"class="reply-btn"@click="setActiveReply(comment.id)">回复</button><!-- 回复输入框 --><CommentInputv-if="activeReplyId === comment.id"@submit="handleSubmit"@cancel="setActiveReply(null)"/><!-- 递归渲染子评论 --><CommentItemv-for="reply in comment.replies":key="reply.id":comment="reply":depth="depth + 1":current-user="currentUser":active-reply-id="activeReplyId":parent-author="comment.author"@reply="$emit('reply', $event)"@set-active-reply="$emit('set-active-reply', $event)"/></div>
</template><script setup>
import { computed } from 'vue'
import CommentInput from './CommentInput.vue'const props = defineProps({comment: Object,depth: Number,currentUser: String,activeReplyId: Number,parentAuthor: String
})const emit = defineEmits(['reply', 'set-active-reply'])const maxDepth = 4
const canReply = computed(() => props.depth < maxDepth)const handleSubmit = (content) => {emit('reply', { parentId: props.comment.id,content })
}const setActiveReply = (id) => {emit('set-active-reply', id)
}
</script><style scoped>
/* 保持与 React 版本相同的样式 */
.comment-item {margin: 16px 0;padding: 12px;border: 1px solid #eee;border-radius: 4px;
}.comment-header {display: flex;align-items: center;margin-bottom: 8px;color: #666;
}.comment-author {font-weight: bold;margin-right: 8px;
}.reply-to {color: #999;margin-right: 8px;
}.comment-time {font-size: 0.9em;
}.reply-btn {background: none;border: none;color: #1890ff;cursor: pointer;padding: 4px 8px;
}
</style>
<!-- CommentInput.vue -->
<template><div class="comment-input-container"><textareav-model="content"placeholder="输入评论内容..."rows="3"></textarea><div class="input-buttons"><button @click="handleSubmit">提交</button><button @click="$emit('cancel')">取消</button></div></div>
</template><script setup>
import { ref } from 'vue'const content = ref('')
const emit = defineEmits(['submit', 'cancel'])const handleSubmit = () => {if (content.value.trim()) {emit('submit', content.value)content.value = ''}
}
</script><style scoped>
.comment-input-container {margin: 16px 0;
}.comment-input-container textarea {width: 100%;padding: 8px;margin-bottom: 8px;
}.input-buttons button {margin-right: 8px;padding: 4px 12px;
}
</style>
组件特性说明:
- Vue3 实现特点:
- 使用 Composition API +
<script setup>
语法 - 通过
defineProps
定义组件参数 - 通过
defineEmits
声明自定义事件 - 响应式系统使用
ref
和computed
- 样式使用 scoped CSS
- 使用方式:
<template><CommentComponent:initial-comments="comments"current-user="当前用户"/>
</template><script setup>
import CommentComponent from './components/CommentComponent.vue'const comments = [{id: 1,author: '用户A',content: '第一条评论',time: '2023-08-01 10:00',replies: [{id: 2,author: '用户B',content: '第一条回复',time: '2023-08-01 10:05'}]}
]
</script>
- 与 React 版本的差异处理:
- 状态管理:用
ref
替代useState
- 事件处理:用
emit
替代 props 回调 - 递归组件:通过组件自身名称实现递归
- 响应式更新:直接操作数组触发响应式更新
- 样式处理:使用 scoped CSS 避免样式污染
- 扩展建议:
<!-- 增加点赞功能示例 -->
<template><button class="like-btn":class="{ liked: comment.liked }"@click="toggleLike">{{ comment.likes || 0 }} 👍</button>
</template><script setup>
// 在 CommentItem 中添加
const toggleLike = () => {context.emit('like', props.comment.id)
}
</script>
这个 Vue3 实现保留了 React 版本的核心功能,同时遵循 Vue 的响应式模式和组件通信方式,更适合 Vue 技术栈项目使用。
相关文章:
VUE3:封装一个评论回复组件
之前用React封装的评论回复组件,里面有三个主要部分:CommentComponent作为主组件,CommentItem处理单个评论项,CommentInput负责输入框。现在需要将这些转换为Vue3的组件。 Vue3和React在状态管理上有所不同,Vue3使用r…...
DELL R740服务器闪黄灯不开机故障案例
1:DELL R740服务器 2:东莞长安客户工厂晚上十一二点电路跳闸多次,导致R740 ERP服务器无法开机。 3:故障现象为:主机能正常通电,开机按钮无通电迹象,正常情况会闪绿灯慢闪,通电一会后…...
记录一下QA(from deepseek)
Q1:__init__.py文件 在 Python 中,当你在一个目录下创建 __init__.py 文件时,这个目录会被视为一个 包(Package)。包的存在使得 Python 能够通过点号(.)层级式地组织模块(.py 文件)&…...
码蹄集——进制输出、求最大公约数、最小公倍数
进制乱炖 本题考查输出的进制转换,可以直接使用c里的format格式输出 #include<iostream> #include<algorithm> #include<string> using namespace std;int main() {int x;cin>>x;printf("%d %o %x %u\n",x,x,x,x);//十进制 八进…...
从技术走向管理:带来哪些角色转变与挑战
文章目录 一、从技术到管理1、从技术转到管理的优劣势(1)优势(2)劣势 2、刚转岗容易犯的几个问题3、最大的变化:不再是一个人单打独斗4、警惕:一开始不要把“人”过早的介入到“事”5、如何完成角色的转变&…...
C语言-指针(一)
目录 指针 内存 概念 指针变量 取地址操作符(&) 操作符“ * ” 指针变量的大小 注意 指针类型的意义 作用 void * 指针 const修饰指针变量 const放在*前 const放在*后 双重const修饰 指针的运算 1.指针 - 整数 2.指针 - 指针 3.指…...
Python面试问题
一、Python 基础 1. Python 的特点 动态类型:变量无需声明类型。解释型语言:逐行解释执行。支持多种编程范式(面向对象、函数式、过程式)。 2. 列表(List)与元组(Tuple)的区别 特…...
RAG工程-基于LangChain 实现 Advanced RAG(预检索优化)
Advanced RAG 概述 Advanced RAG 被誉为 RAG 的第二范式,它是在 Naive RAG 基础上发展起来的检索增强生成架构,旨在解决 Naive RAG 存在的一些问题,如召回率低、组装 prompt 时的冗余和重复以及灵活性不足等。它重点聚焦在检索增强࿰…...
【时时三省】(C语言基础)循环结构程序设计习题1
山不在高,有仙则名。水不在深,有龙则灵。 ----CSDN 时时三省 习题1 输入两个正整数m和n,求其最大公约数和最小公倍数。 解题思路: 求两个正整数 m 和 n 的最大公约数通常使用辗转相除法(欧几里得算法ÿ…...
[密码学实战]SDF之设备管理类函数(一)
[密码学实战]SDF之设备管理类函数(一) 一、标准解读:GM/T 0018-2023核心要求 1.1 SDF接口定位 安全边界:硬件密码设备与应用系统间的标准交互层功能范畴: #mermaid-svg-s3JXUdtH4erONmq9 {font-family:"trebuchet ms",verdana,arial,sans-serif;font-size:16p…...
CDGP|如何建立高效的数据治理团队?
近年来,数据治理行业迅速发展,越来越多的企业开始重视并投入大量资源来建立和完善数据治理体系。数据治理体系不仅能够帮助企业更好地管理和利用数据资源,提升数据质量和数据价值,还能够为企业带来竞争优势和可持续发展能力。 然…...
如何评价 DeepSeek 的 DeepSeek-V3 模型?
DeepSeek-V3 是由杭州 DeepSeek 公司于 2024 年 12 月 26 日发布的一款开源大语言模型,其性能和创新技术在国内外引起了广泛关注。从多个方面来看,DeepSeek-V3 的表现令人印象深刻,具体评价如下: 性能卓越 DeepSeek-V3 拥有 6710 …...
【基础篇】prometheus命令行参数详解
文章目录 本篇内容讲解命令行参数详解 本篇内容讲解 prometheus高频修改命令行参数详解 命令行参数详解 在页面的/页面上能看到所有的命令行参数,如图所示: 使用shell命令查看 # ./prometheus --help usage: prometheus [<flags>]The Promethe…...
SpringBoot实现接口防刷的5种高效方案详解
目录 前言:接口防刷的重要性 方案一:基于注解的访问频率限制 实现原理 核心代码实现 使用示例 优缺点分析 方案二:令牌桶算法实现限流 算法原理 核心实现 配置使用 适用场景分析 方案三:分布式限流(Redis …...
DeepSearch复现篇:QwQ-32B ToolCall功能初探,以Agentic RAG为例
DeepSearch复现篇:QwQ-32B ToolCall功能初探,以Agentic RAG为例 作者:CyPaul Space 原文地址:https://zhuanlan.zhihu.com/p/30289363967 全文阅读约3分钟~ 背景 今天看到 论文:Search-R1: Training LLMs to Reason …...
项目实战-贪吃蛇大作战【补档】
这其实算是一个补档,因为这个项目是我在大一完成的,但是当时没有存档的习惯,今天翻以前代码的时候翻到了,于是乎补个档,以此怀念和志同道合的网友一起做项目的日子 ₍ᐢ ›̥̥̥ ༝ ‹̥̥̥ ᐢ₎♡ 这里面我主要负责…...
power bi获取局域网内共享文件
power bi获取局域网内共享文件 需求: 数据源并不一定都是在本地,有可能在云端,也有可能在其他服务器,今天分享如果数据源在另外一台服务器,如何获取数据源的方法。 明确需求:需要通过PowerBI获取局域网中的…...
100%提升信号完整性:阻抗匹配在高速SerDes中的实践与影响
一个高速信号SerDes通道(例如PCIe、112G/224G-PAM4)包含了这些片段: 传输线连通孔(PTH or B/B via)连接器高速Cable锡球(Ball and Bump) 我们会希望所有的片段都可以有一致的阻抗,…...
第六章:Tool and LLM Integration
Chapter 6: Tool and LLM Integration 从执行流到工具集成:如何让AI“调用真实世界的技能”? 在上一章的执行流框架中,我们已经能让多个代理协作完成复杂任务。但你是否想过:如果用户要求“查询实时天气”或“打开网页搜索”&…...
prompt提示词编写技巧
为什么学习prompt编写 目的:通过prompt的编写,提升LLM输出相关性、准确性和多样性,并对模型输出的格式进行限制,满足我们的业务需求。 学过提示词工程的人:像“专业导演”,通过精准指令控制 AI 输出&#…...
Nginx配置SSL详解
文章目录 Nginx配置SSL详解1. SSL/TLS 基础知识2. 准备工作3. 获取SSL证书4. Nginx SSL配置步骤4.1 基础配置4.2 配置说明 5. 常见配置示例5.1 双向认证配置5.2 多域名SSL配置 6. 安全优化建议7. 故障排查总结参考资源下载验证的完整实例 Nginx配置SSL详解 1. SSL/TLS 基础知识…...
网络安全之红队LLM的大模型自动化越狱
前言 大型语言模型(LLMs)已成为现代机器学习的重要支柱,广泛应用于各个领域。通过对大规模数据的训练,这些模型掌握了多样化的技能,展现出强大的生成与理解能力。然而,由于训练数据中难以完全剔除有毒内容&…...
【技术笔记】通过Cadence Allegro创建一个PCB封装(以SOT23为例)
【技术笔记】通过Cadence Allegro创建一个PCB封装(以SOT23为例) 一、焊盘创建二、PCB封装设计三、丝印位号及标识添加 更多内容见专栏:【硬件设计遇到了不少问题】、【Cadence从原理图到PCB设计】 一、焊盘创建 首先要找到元器件的相关手册&…...
新环境注册为Jupyter 内核
1. 确认环境是否已注册为内核 在终端运行以下命令,查看所有已注册的内核: jupyter kernelspec list2. 为自定义环境注册内核 步骤 1:激活目标虚拟环境 conda activate your_env_name # 替换为你的环境名步骤 2:安装…...
[Spring] Seata详解
🌸个人主页:https://blog.csdn.net/2301_80050796?spm1000.2115.3001.5343 🏵️热门专栏: 🧊 Java基本语法(97平均质量分)https://blog.csdn.net/2301_80050796/category_12615970.html?spm1001.2014.3001.5482 🍕 Collection与…...
使用JDK的数据校验和Spring的自定义注解校验前端传递参数的两种方法
第一种:JDK的数据校验注解 PostMapping("/test")public String test(QueryParam param, RequestHeader(value "App_key") String App_key,RequestHeader(value "App_secret") String App_secret) throws IOException {param.setApp…...
JS错误处理的新方案 (不使用try-catch)
错误处理一直是JavaScript开发者需要认真对待的问题,传统的try-catch语法虽然简单直观,但在异步代码中使用时存在诸多限制。 try-catch的局限性 传统try-catch模式在现代JavaScript开发中面临的问题: 1. 异步错误捕获的缺陷 try-catch无法…...
前端实现商品放大镜效果(Vue3完整实现)
前端实现商品放大镜效果(Vue3完整实现) 前言 在电商类项目中,商品图片的细节展示至关重要。放大镜效果能显著提升用户体验,允许用户在不跳转页面的情况下查看高清细节。本文将基于Vue3实现一个高性能的放大镜组件,完整…...
redis未授权访问漏洞学习
一、Redis常见用途 1. Redis介绍 全称与起源: Redis全称Remote Dictionary Service(远程字典服务),最初由antirez在2009年开发,用于解决网站访问记录统计的性能问题。发展历程: 从最初仅支持列表功能的内存数据库,经过十余年发展已支持多种…...
阿里qiankun微服务搭建
主服务 chat vue3 ts vite 子服务 ppt react 18 vite 子服务 agent 主服务 npm i vite-plugin-qiankun mian.ts import ./style/base.scss import virtual:svg-icons-register import { createApp } from vue import { createPinia } from piniaimport App from ./App.vue im…...
【CodeSprint】第二章-2.1 简单模拟
第二章 2.1 简单模拟 ✏️ 关于专栏:专栏用于记录 prepare for the coding test。 1. 简单模拟 简单模拟题目不需要复杂算法,直接按照题意一步步模拟即可。 1.1 促销计算 题目描述 某百货公司为了促销,采用购物打折的优惠方法:…...
Golang实现函数默认参数
golang原生不支持默认参数 在日常开发中,我们有时候需要使用默认设置,但有时候需要提供自定义设置 结构体/类,在Java我们可以使用无参、有参构造函数来实现,在PHP中我们也可以实现(如 public function xxx($isCName false, $sec…...
【Python Web开发】03-HTTP协议
文章目录 1. HTTP协议基础1.1 请求-响应模型1.2 请求方法1.3 请求和响应结构1.4 状态码 2. Python 发送 HTTP 请求2.1 urllib库2.2 requests 库 3. Python 构建 HTTP 服务器3.1 http.server模块3.2 Flask 框架 4. HTTP 协议的安全问题5. 缓存和性能优化 HTTP(Hypert…...
提高营销活动ROI:大数据驱动的精准决策
提高营销活动ROI:大数据驱动的精准决策 大家好,我是Echo_Wish。今天我们来聊聊如何通过大数据来提高营销活动的ROI(投资回报率)。我们都知道,随着市场的日益竞争,营销的成本不断增加,如何在这片红海中脱颖而出,不仅需要精准的营销策略,还需要依靠先进的技术,尤其是大…...
前端excel导出
在数据可视化和管理日益重要的今天,前端实现 Excel 导出功能已经成为众多项目中的刚需。 一、Excel 导出的常见场景 数据报表导出:在企业管理系统、数据分析平台中,用户经常需要将系统中的数据以 Excel 表格的形式导出,便于离…...
pymsql(SQL注入与防SQL注入)
SQL注入: import pymysql# 创建数据库连接 返回一个对象 conn pymysql.connect(host"localhost", # MySQL服务器地址 本地地址 127.0.0.1user"root", # 用户名 (账号)password"155480", # 密码database&qu…...
基于Springboot + vue + 爬虫实现的高考志愿智能推荐系统
项目描述 本系统包含管理员和学生两个角色。 管理员角色: 个人中心管理:管理员可以管理自己的个人信息。 高校信息管理:管理员可以查询、添加或删除高校信息,并查看高校详细信息。 学生管理:管理员可以查询、添加或…...
delphi使用sqlite3
看了一下delphi调用sqlite3最新版本的调用,网上说的都很片面,也没有完整的资料了。 我自己研究了一下,分享出来。 在调用demo中,官方也给了一个demo但是功能很少,没有参考价值。 1.定义: 首先把sqlite3…...
高压开关柜局部放电信号分析系统
高压开关柜局部放电信号分析系统 - 开发笔记 1. 项目概述 这个项目是我在2025年实现的高压开关柜局部放电信号分析系统,目的是通过采集分析局部放电信号,判断设备的工作状态和潜在故障。系统包含从信号模拟生成、特征提取、到深度学习模型训练的全流程…...
ai环境conda带torch整体迁移。
conda打包好的GPU版torch环境,其实很简单,就是conda装好的torch环境env整体打包,然后到新机器上再解压到env路径。 打开搭建好的环境,找自己路径,我默认的是这个。 cd/root/anaconda3/envs/ 然后整个文件夹打包。tar -…...
电价单位解析与用电设备耗电成本计算
一、电价单位 元/kWh 的解析 定义: 元/kWh 表示每千瓦时电能的费用,即1度电的价格。例如,若电价为0.5元/kWh,则使用1千瓦的电器1小时需支付0.5元。 电价构成: 中国销售电价由四部分组成: 上网电价…...
辛格迪客户案例 | 华道生物细胞治疗生产及追溯项目(CGTS)
01 华道(上海)生物医药有限公司:细胞治疗领域的创新先锋 华道(上海)生物医药有限公司(以下简称“华道生物”)是一家专注于细胞治疗技术研发与应用的创新型企业,尤其在CAR-T细胞免疫…...
C++(初阶)(十三)——继承
继承 继承概念示例 定义格式 继承和访问方式继承方式访问方式实例 继承类模板基类和派生类之间的转换继承中的作用域隐藏规则选择题 派生类的默认成员函数默认成员函数派生类中的实现 实现一个不能被继承的类继承与友元继承与静态成员多继承及其菱形继承问题虚继承多继承指针偏…...
S09-电机运行时间
感谢粉丝网友的支持,也欢迎你们的讨论和分享。昨天我们简单讨论了一下标准功能块的重要性,仅仅是拿电机块举了一个例子,有粉丝问能否把电机运行时间做到块里面,完善一下功能呢?那是绝对当然的100%可以的啊!…...
大语言模型(LLMs)微调技术总结
文章目录 全面总结当前大语言模型(LLM)微调技术1. 引言2. 为什么需要微调?3. 微调技术分类概览4. 各种微调技术详细介绍4.1 基础微调方法4.1.1 有监督微调(Supervised Fine-Tuning, SFT)4.1.2 全参数微调(F…...
python练习:求数字的阶乘
求数字的阶乘 eg:5的阶乘 54321 """ 求数字的阶乘 eg:5的阶乘 5*4*3*2*1 """count 1 for i in range(1,6):count count * iprint(count)运行结果:...
综合练习一
背景 某银行监管系统,需要设计并实现用户登入记录功能,每个用户登入系统时,系统自动记录登入用户的账户、登入时间、登入失败成功与否信息等,普通用户只能登入登出,管理员可以登入后查看日志及分析统计信息等。 用户…...
List--链表
一、链表 1.1 什么是List? 在C语言中,我们需要使用结构体struct来进行List(链表)的实现: struct ListNode {DataType Data;//DataType是任意类型的变量定义struct ListNode* next;//指向下一个结点的指针变量 }; 与之前的vect…...
SpeedyAutoLoot
SpeedyAutoLoot自动拾取插件 SpeedyAutoLoot.lua local AutoLoot CreateFrame(Frame)SpeedyAutoLootDB SpeedyAutoLootDB or {} SpeedyAutoLootDB.global SpeedyAutoLootDB.global or {}local BACKPACK_CONTAINER BACKPACK_CONTAINER local LOOT_SLOT_CURRENCY LOOT_SLOT…...
编程日志4.23
栈的C顺序表实现 #include<iostream> #include<stdexcept> using namespace std; //模板声明,表明Stack类是一个通用的模板,可以用于存储任何类型的元素T template<typename T> //栈的声明 //Stack类的声明,表示一个栈的…...