跳转到主要内容
你行网

Main navigation

  • 首页
  • Drupal
  • 编程与开发
  • 数据库
  • 操作系统与应用
  • 服务器与运维
  • 社区
User account menu
  • 登录

面包屑

  1. 首页

代码框右上角的复制功能怎么实现

由 hrs, 16 三月, 2025

如图上图,

要在代码框右上角实现复制功能,通常需要结合 HTML、CSS 和 JavaScript 来完成。以下是一个简单的实现示例:

1. HTML 结构


<div class="code-container">
   <pre><code id="code">
$int = 42;          // integer
$float = 3.14;      // float
$string = "Hello";  // string
$bool = true;       // boolean
$array = [1, 2, 3]; // array
$object = new stdClass(); // object
$null = null;       // null
$resource = fopen("file.txt", "r"); // resource
$callable = function() { return "Hello"; }; // callable
   </code></pre>
   <button class="copy-button" onclick="copyCode()">复制</button>
</div>


运行 HTML
2. CSS 样式


.code-container {
   position: relative;
   background: #f4f4f4;
   padding: 10px;
   border: 1px solid #ddd;
   border-radius: 4px;
}
pre {
   margin: 0;
}
.copy-button {
   position: absolute;
   top: 10px;
   right: 10px;
   background: #007bff;
   color: white;
   border: none;
   padding: 5px 10px;
   border-radius: 4px;
   cursor: pointer;
}
.copy-button:hover {
   background: #0056b3;
}


3. JavaScript 功能


function copyCode() {
   const code = document.getElementById('code').innerText;
   navigator.clipboard.writeText(code).then(() => {
       alert('代码已复制到剪贴板!');
   }).catch(err => {
       console.error('复制失败: ', err);
   });
}


4. 完整示例


<!DOCTYPE html>
<html lang="zh-CN">
<head>
   <meta charset="UTF-8">
   <meta name="viewport" content="width=device-width, initial-scale=1.0">
   <title>代码复制示例</title>
   <style>
       .code-container {
           position: relative;
           background: #f4f4f4;
           padding: 10px;
           border: 1px solid #ddd;
           border-radius: 4px;
       }
       pre {
           margin: 0;
       }
       .copy-button {
           position: absolute;
           top: 10px;
           right: 10px;
           background: #007bff;
           color: white;
           border: none;
           padding: 5px 10px;
           border-radius: 4px;
           cursor: pointer;
       }
       .copy-button:hover {
           background: #0056b3;
       }
   </style>
</head>
<body>
   <div class="code-container">
       <pre><code id="code">
$int = 42;          // integer
$float = 3.14;      // float
$string = "Hello";  // string
$bool = true;       // boolean
$array = [1, 2, 3]; // array
$object = new stdClass(); // object
$null = null;       // null
$resource = fopen("file.txt", "r"); // resource
$callable = function() { return "Hello"; }; // callable
       </code></pre>
       <button class="copy-button" onclick="copyCode()">复制</button>
   </div>
   <script>
       function copyCode() {
           const code = document.getElementById('code').innerText;
           navigator.clipboard.writeText(code).then(() => {
               alert('代码已复制到剪贴板!');
           }).catch(err => {
               console.error('复制失败: ', err);
           });
       }
   </script>
</body>
</html>

 

运行 HTML

实现步骤:

HTML:创建一个包含代码和复制按钮的容器。

CSS:设置代码框的样式,并将复制按钮定位在右上角。

JavaScript:使用 navigator.clipboard.writeText 方法将代码复制到剪贴板。

注意事项:
navigator.clipboard.writeText 是现代浏览器支持的 API,如果需要兼容旧版浏览器,可以使用 document.execCommand('copy') 作为备用方案。

如果代码内容较多,可以添加滚动条或限制高度。

通过以上代码,您可以在代码框右上角实现一个简单的复制功能。

  • 登录或注册以发表评论
  • 42 次浏览
内容类型分类
技术文章
文章归类
编程与开发

文章标签

  • HTML

评论

最新文章

  • 内容审核通知 content_moderation_notifications 模块简介
  • 调度程序 scheduler 模块简介
  • 工作流当中的草稿,已发布,很好理解,已归档是怎么理解。
  • 你行网 https://www.dwoke.com seo 关键词
  • brew 是什么命令
  • drupal 9 或 drpal 10 国内内容分享模块 Will Nice social share
  • Views Slideshow - Views Vanilla JavaScript Slideshow (VVJS) 简介和安装方法
  • drupal 11 安装statistics 统计模块
  • drupal11 扩展中找不到Statistics模块
  • drupal11 设置中的“总结摘要”和“切边的” 有什么区别

标签云

adsenseAIapacheaptbadblocksbreadcrumbbrewcentoscertbotckeditorcommandcomposercookiecsharpCSScurlC语言DDEVdiffdnsdockerDreamweaverDrupaldrupal 7drupal 8drupal 9drupal10drupal 11drushExcelfirewalldfirmwareflameshotformgimpgitgzipHTMLHTML5httpdhttp验证inputipjavaJavaScriptJavaSrciptkernelKVMLinuxmavenmbstringmod_expires 模块Mysqlnerdtreenetstatnetworknginxnpmpasswordphpphpmyadminphp扩展RFIDRSSselinuxSEOsharesimple_adsensesshsslStatisticssuperfishsurroundtagcloudstitleubuntuuploadprogressvimVPNVUEWireGuardwpsxdebugyoutubeyumzip主题(theme)二进制五笔分类术语压缩解压哈希值声音字段密码工作流快捷键摄影权限果树种植标签优化模块(module)源地址版本号电子秤电脑基础电脑技巧短信验证端口简介算法网站备份网站运营翻译英语表单视图(views)计算机基础赚钱超五类线网线邮件验证重定向重定向,301错误颜色

相关文章

  • 因权限问题导致drupal cms 无法正常安装,那么该如何解决这个问题
  • kvm虚拟机启动失败:default网络未激活
  • ubuntu 安装kvm 虚拟机
  • foreach 是 PHP 循环语句使用方法
  • implode() 函数的定义和用法
  • Drupal 11 主题制作教程
  • 检查 Composer 是否为官方源
  • 在 Drupal 中权重(Weight)是怎样排序的
  • 解决 Drupal 主题缺失问题
  • 为什么学习php 会一边学,一边忘
RSS源

关于我们

  • 你行网简介
  • 关于我们
  • 版权声明

网站相关

  • 社区论坛
  • 网址导航
  • 网站地图
  • 联系我们

友情链接

  • 英文学习

友情链接2

  • drupal 大学
  • 水滴间
  • 爱码网
  • Apache

友情链接3

  • MySQL
  • php
  • drupalcode

友情链接4

  • Drupal 中国
  • Drupal 老葛
  • 宁浩网
  • drupal 台湾
Copyright © 2019 - 2021 你行网 版权所有  粤ICP备19072650号-1