vue3 复制功能,点击按钮实现复制功能

时间: 2023-07-12 11:51:04 浏览: 303

在 Vue 3 中,我们可以使用与上面相同的 Clipboard API 来实现点击按钮复制文本的功能。以下是一个示例代码:

<template>
  <div>
    <button @click="copyText">复制文本</button>
    <input type="text" v-model="textToCopy" />
  </div>
</template>

<script>
import { ref } from 'vue';

export default {
  setup() {
    const textToCopy = ref('要复制的文本');

    const copyText = () => {
      navigator.clipboard.writeText(textToCopy.value)
        .then(() => {
          console.log('文本已成功复制到剪贴板');
        })
        .catch((error) => {
          console.error('复制文本失败:', error);
        });
    };

    return { textToCopy, copyText };
  },
};
</script>

当用户点击“复制文本”按钮时,代码会将文本框中的文本复制到剪贴板中。这里使用了 Vue 3 的 ref 来创建了 textToCopy 变量,并使用 setup 函数来定义 copyText 函数。由于 copyText 函数和 textToCopy 变量都被返回了,因此它们可以在模板中被使用。值得注意的是,这需要用户的授权才能执行成功。

向AI提问 loading 发送消息图标

相关推荐

zip
飞思卡尔智能车竞赛是一项备受关注的科技赛事,旨在激发学生的创新和实践能力,尤其是在嵌入式系统、自动控制和机器人技术等关键领域。其中的“电磁组”要求参赛队伍设计并搭建一辆能够自主导航的智能车,通过电磁感应线圈感知赛道路径。本压缩包文件提供了一套完整的电磁组智能车程序,这是一套经过实战验证的代码,曾在校级比赛中获得第二名的优异成绩。 该程序的核心内容可能涉及以下关键知识点: 传感器处理:文件名“4sensor”表明车辆配备了四个传感器,用于获取环境信息。这些传感器很可能是电磁感应传感器,用于探测赛道上的导电线圈。通过分析传感器信号的变化,车辆能够判断自身的行驶方向和位置。 数据采集与滤波:在实际运行中,传感器读数可能受到噪声干扰,因此需要进行数据滤波以提高精度。常见的滤波算法包括低通滤波、高斯滤波和滑动平均滤波等,以确保车辆对赛道的判断准确无误。 路径规划:车辆需要根据传感器输入实时规划行驶路径。这可能涉及PID(比例-积分-微分)控制、模糊逻辑控制或其他现代控制理论方法,从而确保车辆能够稳定且快速地沿赛道行驶。 电机控制:智能车的驱动通常依赖于直流电机或无刷电机,电机控制是关键环节。程序中可能包含电机速度和方向的调节算法,如PWM(脉宽调制)控制,以实现精准的运动控制。 嵌入式系统编程:飞思卡尔智能车的控制器可能基于飞思卡尔微处理器(例如MC9S12系列)。编程语言通常为C或C++,需要掌握微控制器的中断系统、定时器和串行通信等功能。 软件架构:智能车软件通常具有清晰的架构,包括任务调度、中断服务程序和主循环等。理解和优化这一架构对于提升整体性能至关重要。 调试与优化:程序能够在比赛中取得好成绩,说明经过了反复的调试和优化。这可能涉及代码效率提升、故障排查以及性能瓶颈的识别和解决。 团队协作与版本控制:在项目开发过程中,团队协作和版本控制工具(如Git)的应用不可或缺,能够保
zip
双闭环直流电机调速系统是一种高效且应用广泛的直流调速技术。通过设置转速环和电流环两个闭环,系统能够对电机的转速和电流进行精准控制,从而提升动态响应能力和稳定性,广泛应用于工业自动化领域。 主电路设计:主电路采用三相全控桥整流电路,将交流电转换为可调节的直流电,为电机供电。晶闸管作为核心元件,通过调节控制角α实现输出电压的调节。 元部件设计:包括整流变压器、晶闸管、电抗器等元件的设计与参数计算,这些元件的性能直接影响系统的稳定性和效率。 保护电路:设计过载保护、短路保护等保护电路,确保系统安全运行。 驱动电路:设计触发电路和脉冲变压器,触发电路用于触发晶闸管导通,脉冲变压器用于传递触发信号。 控制器设计:系统核心为转速调节器(ASR)和电流调节器(ACR),分别对转速和电流进行调控。检测电路用于采集实际转速和电流值并反馈给调节器。 仿真分析:利用MATLAB/SIMULINK等工具对系统进行仿真分析,验证其稳定性和性能指标是否达标。 方案确定与框图绘制:明确系统构成及各模块连接方式。 主电路设计:选择整流电路形式,设计整流变压器、晶闸管等元部件并计算参数。 驱动电路设计:设计触发电路和脉冲变压器,确保晶闸管准确触发。 控制器设计: 转速调节器(ASR):根据转速指令调整实际转速。 电流调节器(ACR):根据ASR输出指令调整电流,实现快速响应。 参数计算:计算给定电压、调节器、检测电路、触发电路和稳压电路的参数。 仿真分析:通过软件模拟系统运行状态,评估性能。 电气原理图绘制:完成调速控制电路的电气原理图绘制。 双闭环控制策略:转速环在外,电流环在内,形成嵌套结构,提升动态响应能力。 晶闸管控制角调节:通过改变控制角α调节输出电压,实现转速平滑调节。 仿真分析:借助专业软件验证设计的合理性和有效性。 双闭环直流电机调速系统设计涉及主电路、驱动电路和控制器设计等多个环节,通过仿
zip
《编译原理》是计算机科学中一门极为重要的课程,主要探讨如何将高级程序设计语言转换成机器可执行的指令。清华大学的张素琴教授在这一领域有着深厚的学术造诣,其编译原理课后习题答案对于学习者而言是非常珍贵的资源。这份压缩文件详细解析了课程中所涉及的概念、理论和方法的实践应用,目的是帮助学生更好地理解编译器设计的核心内容。 编译原理的核心知识点主要包括以下几点: 词法分析:作为编译过程的首要环节,词法分析器会扫描源代码,识别出一个个称为“标记”(Token)的最小语法单位。通常借助正则表达式来定义各种标记的模式。 语法分析:基于词法分析产生的标记流,语法分析器依据文法规则构建语法树。上下文无关文法(CFG)是编译器设计中常用的一种形式化工具。 语义分析:这一步骤用于理解程序的意义,确保程序符合语言的语义规则。语义分析可分为静态语义分析和动态语义分析,前者主要检查类型匹配、变量声明等内容,后者则关注运行时的行为。 中间代码生成:编译器通常会生成一种高级的中间表示,如三地址码或抽象语法树,以便于后续的优化和目标代码生成。 代码优化:通过消除冗余计算、改进数据布局等方式提升程序的执行效率,同时不改变程序的语义。 目标代码生成:根据中间代码生成特定机器架构的目标代码,这一阶段需要考虑指令集体系结构、寄存器分配、跳转优化等问题。 链接:将编译后的模块进行合并,解决外部引用,最终形成一个可执行文件。 错误处理:在词法分析、语法分析和语义分析过程中,编译器需要能够检测并报告错误,例如语法错误、类型错误等。 张素琴教授的课后习题答案覆盖了上述所有核心知识点,并可能包含实际编程练习,比如实现简单的编译器或解释器,以及针对特定问题的解题策略。通过解答这些习题,学生可以加深对编译原理的理解,提升解决问题的能力,为今后参与编译器开发或软件工程实践奠定坚实的基础。这份资源不仅是学习编译原理的有力辅助材料,也是
pdf
内容概要:本文介绍了一种基于环形展开架构的全异步7位逐次逼近寄存器(SAR)模数转换器(ADC),其采样速率为1.75 GS/s,采用3纳米CMOS工艺制造。为了降低功耗并减少设计复杂度,提出了一种无存储器的全异步SAR架构,并引入了双尾反馈(DTFB)动态比较器来满足所需速度并最小化热噪声。该ADC实现了37/49 dB的信噪比(SNDR)/无杂散动态范围(SFDR),面积为0.00055平方毫米,功耗仅为0.69毫瓦。此外,它具有最佳的Walden品质因数(FoMw)为6.9 fJ/转换步长,适用于224 Gb/s PAM4 SerDes接收器中的64路时间交织(TI) ADC系统。 适合人群:从事高速模拟电路设计、SerDes接口开发以及对高精度ADC有研究兴趣的专业人士和研究人员。 使用场景及目标:①适用于需要高带宽、低延迟和低功耗的数据中心网络通信设备;②支持大规模时间交织ADC阵列应用,如高速光纤通信系统;③优化ADC性能,特别是针对PAM4信号处理和高速数据传输的应用。 其他说明:本文详细介绍了ADC的关键技术细节,包括但不限于环形展开SAR架构、DTFB比较器设计、门控提升采样保持开关以及各种校准机制。此外,还展示了实测结果并与现有先进技术进行了对比,证明了所提出的ADC在性能和能效方面的优势。该设计方案不仅在单通道ADC中表现出色,在多通道应用场景下同样具备显著的竞争优势。

大家在看

recommend-type

虚幻引擎3D角色动画工作流

当3D建模师或动画师在Maya/3ds MAX/Blender等软件(下述将这些软件简称为DCC,Digital Content Creation)中制作3D模型或动画时应该遵循怎样的制作规范? 在模型或动画制作完成后应该怎样将其导入到虚幻引擎中?通常我们会在DCC工具中将制作好的资源导出成FBX文件,然后在虚幻引擎中导入FBX文件,FBX文件是如此重要以至于我们需要深刻的认识它。当然现在也有一些工作流插件可以直接将DCC工具中制作的模型或动画直接传递给虚幻引擎,在这个过程中我们将不会再看到FBX文件。 模型或动画被导入到虚幻引擎后,在虚幻引擎中应该怎样使用这些资源? 如果多个角色的骨骼相同或非常相似,应该怎样复用动画资源而不是让动画师重复的制作这些动画? 在虚幻引擎中驱动动画(在什么时候该播什么动画)的玩意叫动画蓝图,动画蓝图是与骨骼严格绑定的,当游戏中不同骨骼的角色拥有相同的动画播放逻辑,此时应该怎样避免对每种骨骼都创建相同逻辑的动画蓝图,换句话说应该怎样复用动画蓝图? 在本课程中我们将解决上述问题。 注意:本课程并不涉及如何制作漂亮的角色和帅气的动画,本课程重点讲的是
recommend-type

RD_FMCW.zip

FMCW实现SAR成像,近距离SAR成像,range-doppler算法,matlab仿真。
recommend-type

云计算——刘鹏主编,国内第一本关于云计算的教材

云计算研发团队全面深入剖析云计算技术的权威书籍,对于刚接触云计算的童鞋来说更是一本不可多得的好书。
recommend-type

The GNU Toolchain for ARM targets HOWTO.pdf

英文原版的介绍怎样制作交叉编译工具的资料
recommend-type

SmartSVN license

和谐SmartSVN试用版的license,下载后覆盖即可。(注意:覆盖前最好备份原license)

最新推荐

recommend-type

Vue拖拽组件列表实现动态页面配置功能

在本文中,我们将探讨如何使用Vue.js框架实现一个拖拽组件列表来构建动态页面配置功能。这个功能允许用户通过从右侧的组件库中选择并拖拽组件到左侧,以自定义构建页面视图。同时,左侧的组件可以进行上下拖动以调整...
recommend-type

GEC6818开发板(教学板)

GEC6818的Linux环境安装
recommend-type

WPF实现左右滑动切换图片的小程序

在探讨如何利用WPF(Windows Presentation Foundation)实现滑动条更换图片的功能时,首先需要对WPF的基本概念和相关技术有所了解。 WPF是一个用于开发Windows桌面应用程序的UI框架,它允许开发者利用XAML(可扩展应用程序标记语言)创建界面,并结合.NET框架进行编程。WPF的核心优势在于其丰富的视觉效果、数据绑定能力、可扩展性和硬件加速。它支持复杂的视觉设计和丰富的交互性,非常适合进行复杂的用户界面设计。 ### 1. XAML与C#结合使用 实现WPF滑动条换图片的基本思路是,使用XAML定义界面布局,将滑动条(Slider)控件和图片显示控件(例如Image)放置于界面上,并利用C#代码实现滑动条值改变时触发的事件处理逻辑,从而达到更换图片的目的。 ### 2. 控件介绍 **Slider控件**: 在WPF中,Slider控件用于创建滑动条。它具有Minimum、Maximum、Value等属性,分别代表滑动条的最小值、最大值和当前值。通过设置这些属性,开发者可以定义滑动条的范围和用户可选择的值。 **Image控件**: Image控件用于显示图片。它有一个Source属性,可以通过设置该属性来指定显示的图片。Source属性可以接受多种类型的值,例如bitmap、png等格式的图片文件。 ### 3. 实现逻辑 要实现滑动条更换图片的功能,核心步骤如下: 1. **准备图片资源**: 将需要显示的图片放入项目的文件夹中,并在项目中建立一个图片资源列表,例如一个数组或列表,里面存放所有图片文件的相对路径或绝对路径。 2. **设置Slider控件的属性**: 需要确保Slider控件的Minimum属性设置为0,Maximum属性设置为图片数量减1(即图片索引的上限)。这样,滑动条的值就可以对应到数组索引。 3. **绑定事件处理逻辑**: 将Slider的Value属性通过数据绑定与图片索引相绑定。当滑动条的值发生变化时(即用户拖动滑动条时),会触发一个事件处理函数。 4. **图片更换逻辑**: 在事件处理函数中,根据滑动条的Value属性值来选择图片。将当前图片路径设置到Image控件的Source属性中。这里需要确保索引不会越界,即在图片总数范围内。 5. **异常处理**: 在图片路径设置之前,应进行判断,确保路径有效,避免程序因为无法找到文件而异常退出。可以进行异常捕获或者预先检查路径是否存在。 ### 4. 示例代码 以下是一个简化的C#代码示例,用于说明如何在WPF中实现滑动条更换图片的基本逻辑: ```csharp // 假设有一个图片数组 string[] imagePaths = new string[] { "image1.png", "image2.png", ... }; private void Slider_Loaded(object sender, RoutedEventArgs e) { // 与滑动条的Maximum属性绑定 this.Slider.Value = imagePaths.Length - 1; } private void Slider_SelectionChanged(object sender, SelectionChangedEventArgs e) { // 确保值在有效范围内 if (this.Slider.Value >= 0 && this.Slider.Value < imagePaths.Length) { // 设置图片源 ImageControl.Source = new BitmapImage(new Uri(imagePaths[(int)this.Slider.Value])); } else { // 处理异常情况 MessageBox.Show("图片索引超出范围"); } } ``` 在这个示例中,`Slider_Loaded`是滑动条加载完成时触发的事件处理函数,在该函数中设置了滑动条的最大值。`Slider_SelectionChanged`是滑动条值变化时触发的事件处理函数,在该函数中根据滑动条的值更换图片。 ### 5. 总结 使用WPF实现滑动条更换图片是一个结合XAML布局设计与C#后端逻辑处理的典型示例。通过理解WPF中的事件处理、数据绑定、异常处理等概念,并将这些知识应用到实际项目中,可以创建出美观且功能强大的桌面应用程序。在实际开发过程中,还需要考虑用户界面的美观性、操作的流畅性和异常的鲁棒性等因素,以提高用户体验。
recommend-type

【EasyX文本框性能提升秘籍】:专家级技巧优化交互体验

# 1. EasyX文本框概述及性能问题 在信息技术飞速发展的今天,用户界面(UI)的响应速度和视觉效果对于提升用户体验至关重要。EasyX 是一个轻量级的图形库,它提供了一系列丰富的接口以简化文本框等界面元素的创建和管理。尽管 EasyX 在易用性和轻量级方面具有优势,但其文本框组件在高性能应用场合中面临着诸多挑战,特别是当处
recommend-type

基于YOLOv8锥桶检测

<think>好的,用户想用YOLOv8实现锥桶检测。首先,我需要回忆YOLOv8的相关知识,知道它是Ultralytics维护的最新版本,相比YOLOv5可能有一些改进。用户之前可能了解过YOLOv5,现在想升级到v8,所以需要比较两者的差异,但重点还是放在实现步骤上。接下来,用户需要具体的教程,所以步骤要详细。首先,环境配置是基础,需要安装Ultralytics的库,可能还需要PyTorch和CUDA支持GPU加速。然后,数据准备是关键,用户可能需要收集锥桶的图片,标注成YOLO格式,也就是txt文件,每个对象一行,包括类别、中心坐标和宽高。这里要提醒用户注意数据集的划分,比如训练集、验证
recommend-type

多目标视频跟踪技术详解与粒子滤波应用

视频跟踪技术是计算机视觉和图像处理领域的一项核心技术,它涉及到从视频序列中自动检测和跟踪感兴趣目标(如人、车辆、动物等)。当提到“多目标跟踪”时,意味着系统可以同时跟踪视频中的多个目标,并将它们区分开来。这对于智能监控、人机交互、自动驾驶车辆等应用场景至关重要。 描述中提到的“实时效果还好”,这暗示了该视频跟踪系统具有较好的处理速度,能够快速响应视频中的变化,并且对多目标进行跟踪时的准确度和稳定性较高,这对于实际应用来说是非常重要的。实时跟踪能够为用户提供及时的反馈,这对于需要快速响应的应用场景尤为关键。 针对标签“视频跟踪 多目标”,以下是详细的知识点: 1. 多目标跟踪算法: - 目标检测:多目标跟踪的第一步是目标检测,即在视频帧中识别出所有的目标物体。常用的算法有YOLO(You Only Look Once)、SSD(Single Shot MultiBox Detector)、Faster R-CNN等。 - 跟踪算法:检测到目标后,需要使用特定算法进行跟踪。常见的跟踪算法有卡尔曼滤波、均值漂移、光流法、以及基于深度学习的方法如Siamese Networks、DeepSORT等。 - 数据关联:多目标跟踪的一个挑战是如何将一帧中的目标与之前帧中的目标正确对应,即解决数据关联问题。粒子滤波器(Particle Filter)是一种常用的解决方法。 2. 粒子滤波器(Particle Filter): 粒子滤波器是一种基于蒙特卡洛方法的递归贝叶斯滤波技术,它通过一组随机样本(粒子)来表示概率分布,每个粒子代表一个可能的系统状态。在多目标跟踪中,粒子滤波器能够根据视频帧中的观测数据来更新每个目标的状态估计。 粒子滤波器工作原理: - 初始化:为每个目标生成一组随机粒子,每个粒子代表一个可能的状态。 - 预测:根据系统的动态模型,对下一时刻每个粒子的状态进行预测。 - 更新:当新的观测数据到来时,对每个粒子的权重进行更新,权重反映了粒子代表的状态与实际观测的匹配程度。 - 重采样:根据粒子的权重进行重采样,去除权重较低的粒子,复制权重较高的粒子,从而得到新的粒子集。 - 输出:粒子集的均值或其他统计特性作为目标状态的估计。 3. 应用场景: - 智能监控:在安全监控中,需要实时跟踪视频中的人物或车辆,进行行为分析和异常检测。 - 人机交互:在增强现实或交互式游戏场景中,需要准确跟踪用户的身体部位或手部动作。 - 自动驾驶:自动驾驶车辆需要实时跟踪道路上的其他车辆、行人以及各种障碍物,以确保行车安全。 4. 技术挑战: - 目标遮挡:当目标被遮挡或部分遮挡时,正确地识别和跟踪目标变得困难。 - 目标交互:多目标之间的交互(如相交、相离)可能会对跟踪算法造成干扰。 - 算法效率:实时跟踪对算法的计算效率要求很高,需要在保持跟踪准确性的同时,降低算法的计算复杂度。 以上是基于给定文件信息的详细知识点。视频跟踪技术的多目标实时跟踪功能对众多行业提供了深远的影响,其发展也带来了对计算资源、算法优化等方面的挑战,这需要不断地研究和创新来解决。
recommend-type

【紧急!EasyX文本框问题速查手册】:快速定位与解决常见难题

# 1. EasyX文本框问题速查概述 在图形用户界面(GUI)编程中,文本框是一个基础且核心的组件,承担着与用户进行信息交互的主要任务。EasyX文本框作为一款简便的图形库,为文本交互提供了直观的解决方案。然而,在实际开发过程中,开发者经常遇到各种与文本框相关的问题,如绘制错误、布局不合理、输入处理不当等。本章将概述EasyX文本框
recommend-type

UInputComponent

<think>好的,我需要回答用户关于Unreal Engine中UInputComponent的实现和使用的问题。用户之前已经询问过SetupPlayerInputComponent的相关内容,现在想更深入了解UInputComponent的具体实现和解决相关问题。我需要结合之前的回答和用户提供的引用内容,但注意用户提到这些引用可能不直接相关,需要更多参考用户的上一次问题和我的回答。 首先,我需要回顾UInputComponent的基本功能。它是处理输入绑定的核心组件,负责将输入事件(如按键、鼠标动作)映射到游戏角色的函数。在之前的回答中,我提到了如何在角色类中重写SetupPlayerI
recommend-type

深入探讨SOA模式:英文版电子书

SOA(面向服务的架构)模式是一种流行的企业架构方法,它基于松耦合的服务的概念,允许企业将业务流程作为独立服务集成到业务中。SOA模式的设计思想是把原本在企业内部的、分散的、不标准的业务过程整合成一系列相互关联且可重复利用的服务。 ### 知识点详解: 1. **面向服务的架构(SOA)基础** - **服务的定义**:在SOA中,服务通常是一种独立可调用的业务功能,它封装了特定业务逻辑,能够响应各种请求。服务之间通过明确定义的接口进行交互。 - **服务的独立性**:服务应该是独立的,这意味着服务的变更不应该影响其他服务。 - **服务的重用性**:良好的设计允许服务能够被不同系统在不同上下文中重用。 - **松耦合**:SOA强调的是服务之间的松耦合,即服务之间相互依赖性低,从而实现系统的灵活性和可扩展性。 2. **SOA的组件与原则** - **服务注册中心**:它是服务目录,所有服务都必须在注册中心进行注册,以便其他服务能够发现它们。 - **服务消费者(客户端)**:这指的是需要利用服务的应用程序。 - **服务提供者**:这是服务的创建者,负责发布和维护服务。 - **服务合约**:也称为服务接口,它定义了服务的功能以及如何与服务进行交互。 3. **SOA的模式** - **服务编排(Service Orchestration)**:这个模式涉及多个服务的协作以完成一个复杂的业务流程。通常由一个服务协调者进行管理。 - **服务聚合(Service Aggregation)**:服务聚合涉及将多个服务的结果合并到一个单一的服务接口中。 - **服务代理(Service Broker)**:在服务代理模式中,服务代理负责服务的发现、绑定以及服务生命周期管理。 - **服务治理(Service Governance)**:这包括定义和维护服务如何被创建、发布、管理和消亡的政策和标准。 4. **SOA的优势和挑战** - **优势**:包括提高业务灵活性、服务重用、系统集成和降低复杂性。 - **挑战**:包括确保服务质量和性能、数据一致性、安全性和管理大量服务的复杂性。 5. **Manning Publications出版的《SOA Patterns》** - Manning Publications是一家知名的出版机构,专注于技术领域的图书和电子书。《SOA Patterns》无疑是该领域的权威读物,它详细介绍了多种在实际SOA实施过程中可以应用的设计模式。 - 通过研究这些模式,开发者和架构师可以了解如何构建具有高可用性、可伸缩性和灵活性的系统。 6. **在企业中的应用** - SOA模式可以应用在需要提高业务流程自动化、跨部门协作和系统集成的企业中。 - 它特别适合在不断变化的市场环境中需要快速适应和演进的企业架构。 ### 结论 《SOA Patterns》电子书深入探讨了SOA的各个方面,不仅为IT专业人士提供了理论基础,还提供了实用的设计模式,帮助他们构建健壮的企业级服务架构。理解并掌握SOA模式的知识,对于那些希望优化企业运作、提高效率和适应不断变化市场条件的组织至关重要。通过合理的规划和实施SOA,企业能够实现更好的资源利用,提供更一致的客户体验,以及在竞争激烈的市场中保持领先地位。
recommend-type

【EasyX文本框深度剖析】:6大步骤带你从新手到专家

# 1. EasyX文本框简介与环境搭建 在现代的用户界面设计中,文本框组件是不可或缺的元素,它允许用户输入和编辑文本信息。EasyX 是一个广泛使用的图形界面库,提供了一套功能丰富的文本框API,用于在Windows平台上构建交互式的文本编辑功能。 ## 1.1 文本框组件
手机看
程序员都在用的中文IT技术交流社区

程序员都在用的中文IT技术交流社区

专业的中文 IT 技术社区,与千万技术人共成长

专业的中文 IT 技术社区,与千万技术人共成长

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

关注【CSDN】视频号,行业资讯、技术分享精彩不断,直播好礼送不停!

客服 返回
顶部