新闻中心

使用CSS实现环绕圆形菜单的数字布局

2025-11-16
浏览次数:
返回列表

使用css实现环绕圆形菜单的数字布局

本文旨在指导开发者如何使用CSS实现环绕圆形菜单的数字布局。通过添加额外的wrapper容器,并调整CSS样式中的定位、变换和尺寸属性,可以实现数字围绕圆形菜单的精确环绕效果。本文提供详细的代码示例和步骤,帮助你解决数字定位不准确的问题,并创建一个美观且功能完善的圆形菜单。

在Web开发中,创建具有吸引力的用户界面至关重要。环绕圆形菜单的数字布局是一种常见的交互设计模式,可以用于导航、选项选择等多种场景。本文将详细介绍如何使用CSS来实现这种布局,解决数字位置不准确的问题,并提供优化后的代码示例。

结构调整:添加Wrapper容器

为了更精确地控制数字的位置,我们需要在原有的HTML结构中添加一些wrapper容器。具体来说,我们需要添加一个cn-button-wrapper来包裹中心按钮,以及一个circle-wrapper-outer来包裹数字圆环。

<div class="component csstransforms">
  <div class="cn-button-wrapper">
    <button class="cn-button" id="cn-button">
      @@##@@
    </button>
  </div>

  <div class="cn-wrapper opened-n*" id="cn-wrapper">
    <ul>
      <li>
        <a @click="showMore" href="j*ascript:void(0)"><span class="learn">Learn</span></a>
      </li>
      <li>
        <a @click="showMore2" href="j*ascript:void(0)"><span class="learn1">Review</span></a>
      </li>
      <li>
        <a @click="showMore3" href="j*ascript:void(0)"><span class="learn2">Evaluate</span></a>
      </li>
      <li>
        <a @click="showMore4" href="j*ascript:void(0)"><span class="learn3">Sign-up</span></a>
      </li>
      <li>
        <a @click="showMore5" href="j*ascript:void(0)"><span class="learn4">Engage</span></a>
      </li>
      <li>
        <a @click="showMore6" href="j*ascript:void(0)"><span class="learn5">Share</span></a>
      </li>
      <li>
        <a @click="showMore7" href="j*ascript:void(0)"><span class="learn6">Impact</span></a>
      </li>
      <;li>
        <a @click="showMore8" href="j*ascript:void(0)"><span class="learn7">Transform</span></a>
      </li>
    </ul>
  </div>

  <!-- End of N* Structure -->
</div>

<div class="circle-wrapper-outer">
  <div class="circle-wrapper">
    <div class="circle deg-180-new btnDeactivated" id="btn1">1</div>
    <div class="circle deg-225-new btnDeactivated" id="btn2">2</div>
    <div class="circle deg-270-new btnDeactivated" id="btn3">3</div>
    <div class="circle deg-315-new btnDeactivated" id="btn4">4</div>
    <div class="circle deg-0-new btnDeactivated" id="btn5">5</div>
    <div class="circle deg-45-new btnDeactivated" id="btn6">6</div>
    <div class="circle deg-90-new btnDeactivated" id="btn7">7</div>
    <div class="circle deg-135-new btnDeactivated" id="btn8">8</div>
  </div>
</div>

CSS样式调整

接下来,我们需要修改CSS样式来适应新的HTML结构,并精确地定位数字。

  1. .component: 添加display: flex和justify-content: center,使内容水平居中。

    .component {
      position: relative;
      margin-bottom: 3em;
      height: 15em;
      display: flex; /* Added */
      justify-content: center; /* Added */
    }
  2. .cn-button-wrapper: 设置宽度、高度,并使用Flexbox布局将按钮居中。

    .cn-button-wrapper {
      width: 100%;
      height: calc(34rem + 250px);
      display: flex;
      justify-content: center;
      align-items: center;
      margin-left: 15px;
    }
  3. .cn-button: 移除绝对定位相关的属性,因为我们将使用Flexbox来定位它。

    通用产品企业网站(.NET2.0)1.0 通用产品企业网站(.NET2.0)1.0

    1、系统采用.net2.0开发,数据库access2、三层架构,数据层、逻辑层和表示层分离3、系统完全使用div+css布局,可以灵活处理界面4、技术特点: 使用模板页,大大减少代码量 动态生成竖向导航菜单 ul li实现表格 各种自定义用户空间 Reapter等数据控件的灵活运用

    通用产品企业网站(.NET2.0)1.0 0 查看详情 通用产品企业网站(.NET2.0)1.0
    .cn-button {
      position: absolute;
      /* top: 115%; */ /* Removed */
      /* left: 56%; */ /* Removed */
      z-index: 11;
      /* margin-top: -4.5em; */ /* Removed */
      /* margin-left: -5em; */ /* Removed */
      padding: 0;
      width: 8em;
      height: 8em;
      border: none;
      border-radius: 50%;
      background: none;
      background-color: #004691;
      color: #5f259f;
      text-align: center;
      font-weight: 700;
      font-size: 1em;
      text-transform: uppercase;
      cursor: pointer;
      -webkit-backface-visibility: hidden;
      border: 6px solid #fff;
    }
  4. .circle-wrapper-outer: 设置宽度和绝对定位,用于包裹数字圆环。

    .circle-wrapper-outer {
      width: 100%;
      position: absolute;
      top: 0;
      top: 100px;
    }
  5. .circle-wrapper: 设置固定的宽度和高度,并使用margin-left: auto和margin-right: auto使圆环水平居中。

    .circle-wrapper {
      width: 34rem; /* Added */
      height: 34rem; /* Added */
      border-radius: 50%;
      position: relative;
      transform: rotate(23deg);
      margin-left: auto;  /* Added */
      margin-right: auto;  /* Added */
      top: 0;  /* Added */
    }
  6. .circle: 保持原有的样式,用于数字的显示。

    .circle {
      display: block;
      position: absolute;
      top: 54%;
      left: 54%;
      width: 50px;
      height: 50px;
      margin: -48px -48px -48px -53px;
      background: red;
      border-radius: 51%;
      text-align: center;
      line-height: 50px;
    }
  7. *`.deg--new**: 为每个数字添加新的样式,调整translate`的值以精确控制数字的位置。需要根据实际情况调整这些值,以达到最佳的视觉效果。

    .deg-0-new {
      transform: rotate(45deg) translate(325px) rotate(-65deg);
      background: #5ede29;
      color: white;
      font-weight: 600;
    }
    
    .deg-45-new {
      transform: rotate(90deg) translate(325px) rotate(-110deg);
      background: #ffe816;
      color: white;
      font-weight: 600;
    }
    
    .deg-90-new {
      transform: rotate(135deg) translate(325px) rotate(-158deg);
      background: #f74015;
      color: white;
      font-weight: 600;
    }
    
    .deg-135-new {
      transform: rotate(180deg) translate(325px) rotate(-200deg);
      background: #54bef8;
      color: white;
      font-weight: 600;
    }
    
    .deg-180-new {
      transform: rotate(225deg) translate(305px) rotate(-248deg);
      background: #5ede29;
      color: white;
      font-weight: 600;
    }
    
    .deg-225-new {
      transform: rotate(270deg) translate(305px) rotate(-289deg);
      background: #ffe816;
      color: white;
      font-weight: 600;
    }
    
    .deg-270-new {
      transform: rotate(315deg) translate(315px) rotate(-338deg);
      background: #f74015;
      color: white;
      font-weight: 600;
    }
    
    .deg-315-new {
      background: #54bef8;
      transform: rotate(360deg) translate(325px) rotate(-380deg);
      color: white;
      font-weight: 600;
    }
  8. .csstransforms .cn-wrapper: 调整top属性,使圆形菜单位于正确的位置。

    .csstransforms .cn-wrapper {
      position: absolute;
      /* top: 100%; */ /* Removed */
      /* left: 50%; */ /* Removed */
      z-index: 10;
      top: 100px; /* Added */
      /* margin-top: -16em; */ /* Removed */
      /* margin-left: -15.5em; */ /* Removed */
      width: 34em;
      height: 34em;
      border-radius: 50%;
      font-weight: bold;
      background: transparent;
      -webkit-transition: all 0.3s ease 0.3s;
      -moz-transition: all 0.3s ease 0.3s;
      transition: all 0.3s ease 0.3s;
      -webkit-transform: scale(0.1);
      -ms-transform: scale(0.1);
      -moz-transform: scale(0.1);
      transform: scale(0.1);
      pointer-events: none;
      overflow: hidden;
    }

注意事项

  • 浏览器兼容性: 确保你的CSS代码在不同的浏览器上都能正常工作。可以使用Autoprefixer等工具来自动添加浏览器前缀。
  • 响应式设计: 考虑在不同的屏幕尺寸下调整数字和菜单的位置,以确保良好的用户体验。可以使用媒体查询来实现响应式设计。
  • 性能优化: 避免过度使用transform属性,因为它可能会影响性能。尽量使用其他CSS属性来实现相同的效果。

总结

通过添加wrapper容器和调整CSS样式,我们可以实现环绕圆形菜单的数字布局,并解决数字定位不准确的问题。这种布局可以用于多种场景,例如导航、选项选择等。通过本文的指导,你可以轻松地创建美观且功能完善的圆形菜单。

logo

以上就是使用CSS实现环绕圆形菜单的数字布局的详细内容,更多请关注其它相关文章!


# 可以使用  # 江苏抖音推广营销知识  # 大邑建设网站报价  # 招聘网站的付费推广  # 教师网站建设美丽图片  # 普洱市seo  # 大乐透营销推广策略  # 红色旅游营销推广方式  # 小说网站怎么推广挣钱的  # 网站建设推广哪个品牌好  # seo黑帽子app推广  # 都能  # 你可以  # 是一种  # 视频文件  # 可以实现  # css  # 不准确  # 来实现  # 如何使用  # 企业网站  # 绝对定  # css属性  # css样式  # 响应式设计  # 工具  # app  # 浏览器  # go  # html  # java  # javascript 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 整合Supabase认证与Django模型:跨模式迁移的解决方案  如何在J*a中实现统一对象行为接口_项目大型化时的接口规范化  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  AI抖音网页版免费视频入口 AI抖音网页端最新视频实时观看  如何使用CaptainHook和Composer管理Git钩子_在提交前自动运行代码检查的Composer配置  单12V-2&#215;6实现为RTX 5090供电750W!甚至都没敢跑分  CSS如何设置hover状态颜色_hover伪类调整背景或文字颜色  TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法  J*aScript中在Map循环中检测并处理空数组元素  怎么在mac上运行html代码_mac运行html代码方法【指南】  QQ邮箱稳定登录入口_QQ邮箱官方网站网页版使用  MAC怎么让Dock栏只显示当前运行的应用_MAC终端命令实现极简Dock栏  J*a里如何实现线程安全的懒加载单例_懒加载单例实现方法解析  win11怎么查看应用耗电情况 Win11电池设置查看应用能耗排行榜【优化】  QQ邮箱登录官网首页 腾讯QQ邮箱网页入口  迅雷下载到U盘速度很慢怎么办_迅雷U盘下载慢优化方法  俄罗斯方块最新版入口 俄罗斯方块在线玩官网入口  CSS响应式网页如何实现主次模块比例自适应_flex-grow与flex-shrink调整  sublime如何配置Python开发环境_将sublime打造成轻量级Python IDE  怎样更改Windows系统的默认安装路径_避免C盘爆满的终极设置【技巧】  顺丰快件物流信息 官方网站查询入口  J*a最大堆Heapify方法修复:索引计算与边界条件深度解析  在J*a中如何使用BigDecimal进行高精度计算_BigDecimal类应用指南  Golang如何优雅处理error_Golang error处理最佳实践总结  Selenium Python中处理点击后新窗口加载冻结问题的策略与实践  J*a里如何使用N*igableMap进行导航操作_可导航Map操作技巧解析  Android Studio计算器C键逻辑错误排查与修复:条件判断优化指南  手机屏幕碎了但能正常使用怎么办 手机外屏碎裂的修复建议  J*aScript中如何高效提取对象指定属性  QQ邮箱网页版登录入口 QQ邮箱官方在线使用平台  妖精漫画网页版登录入口免费_妖精漫画官网主页直接阅读漫画  J*aScript动态修改指定div内所有a标签样式指南  Flexbox布局实践:实现粘性导航栏与底部固定页脚  必由学网页版入口 必由学官方平台直接访问  谷歌学术网站直达地址 谷歌学术搜索网页版一键进入  谷歌google账号注册详细步骤 谷歌账号注册官方教程  vivo浏览器自带的下载器速度慢怎么办 vivo浏览器提升文件下载速度的技巧  照顾宝贝2小游戏点击立即在线玩  解决移动端滚动问题的overflow属性应用指南  2306选座时如何选靠窗位置_12306选座靠窗座位查看方法解析  Win11怎么修改默认浏览器_Windows 11设置Chrome为默认  Go语言中对Map值调用带指针接收者方法:原理与最佳实践  Composer如何处理Git子模块(submodule)依赖_Composer与Git Submodule的对比与选择  蛙漫漫画免费阅读入口_蛙漫官方正版无广告纯净版  Go语言JSON解析深度指南:动态访问与结构体映射实践  漫蛙2正版漫画站 漫蛙2网页版快速访问入口  Composer的 "conflict" 字段有什么用_如何声明不兼容的包以避免依赖冲突  MAC如何安全彻底地删除文件_MAC使用终端命令确保文件无法被恢复  Odoo 16:在表单视图中基于当前记录动态修改Tree视图属性  机器学习中对数变换预测结果的反向还原 

搜索