Js实现轮盘抽奖功能,一招帮你解决选择困难症

news2025/1/20 14:54:24

不知道今天自己该吃什么,一招帮你解决选择困难症。
通过html+css+js实现一个轮盘抽奖功能。我们可以将平时吃的饭菜输入到代码中,每到纠结的时候只需点开抽一次就可以了。
在这里插入图片描述

实现步骤

html代码:
整体实现的结构是一个大的圆形,分成了左右两个部分。从上面的图片中我们可以看出,我们是将整个圆形分成了八块的,实现方法就是css的旋转。

<div class="outher">
    <div class="wapper">
        <div class="left">
                <div class="one"> <span class="text"></span></div>
                <div class="two"> <span class="text"></span></div>
                <div class="three"> <span class="text"></span></div>
                <div class="four"> <span class="text"></span></div>
        </div>
        <div class="right">
            <div class="one"> <span class="text"></span></div>
            <div class="two"> <span class="text"></span></div>
            <div class="three"> <span class="text"></span></div>
            <div class="four"> <span class="text"></span></div>
        </div>
     </div>
     <div class="circle">
             抽奖
     </div>
</div>

css代码:
给body设置为flex布局,设置了水平和垂直居中,让整个轮播处于屏幕的中间。

     *{
         margin:0;
         padding:0;
     }

     body{
         display: flex;
         justify-content: center;
         align-items: center;
         height: 100vh;
     }

.outher是整个div块的样式设置,设置为一个圆形.
.wapper是将整个圆形分为八个部分,transform:rotate(22.5deg)定义 2D 旋转,选择了22.5deg正好使得箭头正对着每一部分的中间位置。

     .outher{
         width:300px;
         height: 300px;
         position: relative;
         border-radius: 50%;
     }

     .wapper{
         width:300px;
         height: 300px;
         border-radius: 50%;
         overflow: hidden;
         transform:rotate(22.5deg);
      }

在这里插入图片描述
整个圆的宽度为300px,分成两部分每一部分都是150px。

  .left{
          position: absolute;
          width: 150px;
          height: 300px;
          left:0;
          overflow: hidden;
      }
   .right{
          position: absolute;
          width: 150px;
          height: 300px;
          right:0;
          overflow: hidden;
          text-align: center;
      }

这里设置的transform-origin: right center左半部分以右侧的中心点为转轴旋转,右半部分以左侧的中心点为旋转轴旋转。第一个div块不需要旋转,两部分因分别分成了4块,所以第二个旋转的度数就是45deg,第三个就是90deg。而且给每一部分设置交叉的颜色,区分开每一块。

    .left div{
        position: absolute;
        top:0;
        left:0;
        width: 100%;
        height: 100%;
        transform-origin: right center;
    }
    .left div.one{
        background-color: #FC7C7B;
    }  
    .left div.two{
        background-color: #F59462;
        transform:rotate(-45deg);
    }
    .left div.three{
        background-color: #FC7C7B;
        transform:rotate(-90deg);
    }

    .left div.four{
        background-color: #F59462;
        transform:rotate(-135deg);
    } 
    
   .right div{
        position: absolute;
        top:0;
        left:0;
        width: 100%;
        height: 100%;
        transform-origin: left center;
    } 
    .right div.one{
        background-color: #F59462;
    }
    .right div.two{
        background-color: #FC7C7B;
        transform:rotate(45deg);
    }
    .right div.three{
        background-color: #F59462;
        transform:rotate(90deg);
    }
    .right div.four{  
        background-color: #FC7C7B;
        transform:rotate(135deg);
    } 

每一小部分中文字的样式设置,分别旋转22.5deg处于每一部分的中间位置。

  .left .text{
          position: absolute;
          top:30px;
          left:55%;
          transform:rotate(-22.5deg);
          text-align: center;
      }

      .right .text{
          position: absolute;
          top:25px;
          left:11%;
          transform:rotate(22.5deg);
          text-align: center;
      }

这一部分就是中间抽奖和箭头的样式设置了。箭头就是一个三角形,位置正好处于小圆型的正中心。

    .circle{
        width: 100px;
        height: 100px;
        background-color: white;
        position: absolute;
        left:50%;
        top:50%;
        transform:translate(-50%,-50%);
        border-radius: 50%;
        text-align: center;
        line-height: 100px;
        font-size: 30px;
        font-weight: bold;
        cursor: pointer;
        user-select: none;
    }
    
    .circle:after{
         width: 0;
         height: 0;
         border:40px solid white;
         border-left-width: 10px;
         border-right-width: 10px;
         position: absolute;
         content:"";
         border-left-color: transparent;
         border-top-color: transparent;
         border-right-color: transparent;
         top:-70px;
         left:calc(50% - 10px);
         z-index: -1;
    }

js代码:
在抽奖的过程中,不允许再次点击就设置了一个isFlag,只有当isFlag=true点击的时候才会触发后面的事件。生成一个随机数random,然后再执行switch函数,然后执行相应的run函数,run函数传递两个参数angle角度,text[random]随机的一种菜。

  let wapper = document.querySelector(".wapper");
        let textAll = document.querySelectorAll(".wapper .text");
        let text = ["黄焖鸡","麻辣烫","蛋炒饭","烧烤","火锅","热干面","牛排","螺蛳粉"];
        for(let i = 0 ; i < textAll.length ; i++){
                textAll[i].innerHTML = text[i];  
        }
        let isFlag = true;

         document.querySelector(".circle").onclick=function(){ 
            if(isFlag){
                let random = parseInt(Math.random()*8)
                switch(random){
                    case 0:
                        run(22.5,text[random]);
                        break;
                    case 1:
                        run(66.5,text[random]);
                        break;
                    case 2:
                        run(112.5,text[random]); 
                        break;
                    case 3:
                        run(157.5,text[random]);
                        break;
                    case 4:
                        run(338.5,text[random]);
                        break;
                    case 5:
                        run(294.5,text[random]);
                        break;   
                    case 6:
                        run(247.5,text[random]);
                        break;
                    case 7:
                        run(201.5,text[random]);
                        break;    
                }
            }    
        };

下面的就是run函数的定义,为了让整个轮盘多转几圈,我们先设置了一个基础角度basic=1800,可能一开始的旋转效果比较生硬,这里我们添加一个缓动动画效果,缓动动画公式 (结束位置 - 起始位置)* 缓动系数(0~1)。

      function run(angle,text){
        isFlag = false;
        let begin = 0; 
        let timer = null;
        let basic = 1800;
        timer = setInterval(function(){
            if(begin > (basic+angle)){
                isFlag = true;
                clearInterval(timer);
            }
            wapper.style.transform="rotate("+(begin)+"deg)";
            begin+=Math.ceil(basic+angle-begin)*0.1;
        },70);
    }

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/105964.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

热门项目披露:成都双流板桥轨道城市发展有限公司100%股权转让

热门项目披露&#xff1a;成都双流板桥轨道城市发展有限公司100%股权转让&#xff1b;该项目由 西南联合产权交易所 发布&#xff0c;于2022年12月9日被塔米狗平台收录。 项目方 成都双流板桥轨道城市发展有限公司&#xff0c; 成立于 2021年9月7日 &#xff0c; 注册资金 100…

域控制器交付量「翻番」,汽车中间件赛道竞争升级

作为软件定义汽车的关键环节&#xff0c;智能汽车中间件赛道&#xff0c;正在成为兵家必争之地。 从传统IT架构的角度看&#xff0c;中间件位于上层应用和底层操作系统之间&#xff1b;除了基础的通信交互外&#xff0c;中间件还承载着屏蔽底层复杂性的功能&#xff0c;向下适配…

005:UITableView

介绍&#xff1a; 提示&#xff1a;数据量大、样式较为统一、分组的需要以及滚动的需求。 图示&#xff1a; UITableViewDataSource&#xff1a; 提示UITableView作为视图&#xff0c;只负责展示&#xff0c;协助管理&#xff0c;不管数据需要开发者为UITableView提供展示需…

Framework底层原理——Binder调用流程分析

binder是一个非常好的跨进程通信工具&#xff0c;Android对其进行了各种封装&#xff0c;虽然我们用起来简单&#xff0c;但是理解起来却比较困难。 1.自己设计一个跨进程通信机制 在理解binder之前呢&#xff0c;首先我们想一下&#xff0c;如果我们自己设计一个跨进程通信的…

简单Thinkphp5.1如何使用Topsdk\Topapi

一淘模板&#xff08;56admin.cn&#xff09;给大家介绍tp5.1相关知识&#xff0c;其中主要记录tp5.1是怎么使用Topsdk\Topapi&#xff08;对接淘宝客开放平台&#xff09;&#xff0c;希望对需要的朋友有所帮助&#xff01; 1、公司有一项目需要对接淘宝开放平台 先去申请帐号…

tensorrt debug问题汇总

目录 1. Dynamic dimensions required for input: input, but no shapes were provided. Automatically overriding 2. sampleMNIST.obj : error LNK2019: 无法解析的外部符号 cudaStreamCreate 3. Assertion failed: (smVersion &#xff1c; SM_VERSION_A100) &&…

条码管理系统,助力企业打造轻量级数字化车间

在原辅材料供应、生产管理、仓储物流、市场营销等相关业务环节中&#xff0c;采取适当的软硬件技术手段&#xff0c;实时记录产品信息。通过查询可以随时跟踪产品的生产状态、仓储状态和流向&#xff0c;达到可追溯管理的目的。随着制造企业对精细化管理要求的提高&#xff0c;…

【QT开发笔记-基础篇】| 第五章 绘图QPainter | 5.7 画笔设置

本节对应的视频讲解&#xff1a;B_站_视_频 https://www.bilibili.com/video/BV16W4y1g7dM 经过前面几节课的讲解&#xff0c;学会了绘制点、线、多段线、多边形、矩形、圆角矩形 到这里就可以学习画笔和画刷的设置了&#xff0c;本节先讲解画笔的设置 Qt 中画笔的类是 QPen…

正则表达式验证合集

1.定义封装的公共js 在src下定义一个util文件夹&#xff0c;并且定义个validate.js(当然你想取什么名字就什么名字哈哈哈哈) 2.上代码 //邮箱 /*** 邮箱* param {*} s*/ export function isEmail(s) {return /^([a-zA-Z0-9_-])([a-zA-Z0-9_-])((.[a-zA-Z0-9_-]{2,3}){1,2}…

基于FPGA的 矩阵键盘按键识别 【原理+源码】

目录 引言 原理阐述 实现方法 源码分享 板级调试演示 引言 最近了解了矩阵键盘扫描的原理&#xff0c;动手实现了一下&#xff0c;在这里做一个简单的总结。 原理阐述 矩阵键盘典型电路&#xff1a; FPGA的应用电路&#xff1a; 其中&#xff0c;行信号为FPGA输入信号&a…

企业从哪里开始构建弹性 IT 基础架构

混合工作模式扩大了工作范围&#xff0c;增加了 IT 团队的负担&#xff0c;因为他们需要在面对增加的攻击面时保持弹性。入侵企业的 IT 基础架构只需要一个受损的身份。 什么是企业标识&#xff1f; 这些是用户名、密码、网络、端点、应用程序等&#xff0c;充当业务敏感信息…

CheatEngine教程-官方9关

文章目录第一步&#xff1a;环境准备&#xff0c;下载并安装CE第二关&#xff1a;精确扫描数值第三关&#xff1a;未知数值扫描第四关&#xff1a;浮点数的扫描第五关&#xff1a;代码替换功能第六关&#xff1a;关于指针第七关&#xff1a;简单代码注入第八关&#xff1a;查找…

力扣(LeetCode)173. 二叉搜索树迭代器(C++)

设计 根据二叉树的中序遍历的迭代解法&#xff0c;稍改代码&#xff0c;就是本题的解法。 初始化 : 传入了根结点&#xff0c;根据迭代思路&#xff0c;将结点的左链依次入栈。 nextnextnext : 栈顶结点就是所求。根据迭代思路&#xff0c;当前结点要变成栈顶结点的右儿子。由…

Openlayers:自定义坐标系

Openlayers天然支持EPSG:4326(WGS1984地理坐标系)、EPSG:3857(Web墨卡托投影坐标系,即:将WGS84坐标系投影到正方形,南北投影范围为[-85.051129,+85.051129])。同时,Openlayers也支持开发者自定义坐标系。那么具体如何操作呢? 相关的API ol.proj.projection ol.proj.…

Android设计模式详解之工厂方法模式

前言 工厂方式模式是创建型设计模式&#xff1b; 定义&#xff1a;定义一个用于创建对象的接口&#xff0c;让子类决定实例化哪个类。 使用场景&#xff1a;在任何需要生成复杂对象的地方&#xff0c;都可以使用工厂方法模式。复杂对象适合使用工厂模式&#xff0c;用new就可…

【Java|golang】1753. 移除石子的最大得分

你正在玩一个单人游戏&#xff0c;面前放置着大小分别为 a​​​​​​、b 和 c​​​​​​ 的 三堆 石子。 每回合你都要从两个 不同的非空堆 中取出一颗石子&#xff0c;并在得分上加 1 分。当存在 两个或更多 的空堆时&#xff0c;游戏停止。 给你三个整数 a 、b 和 c &a…

攻防世界新手练习区——unseping

目录 知识点 解读题目源码&#xff1a; 命令绕过 知识点 PHP代码审计PHP序列化和反序列化PHP中魔术方法命令执行绕过方式 解读题目源码&#xff1a; 这道题首先一上来就是一段PHP代码&#xff0c;其中看到unserialize()就知道考的是反序列化&#xff0c;但是我们再往上看代码…

rust编程-struct结构体(chapter 5.1 结构体定义和实例化)

目录 1. 结构体定义和实例化 1.1 struct介绍 1.2 使用字段简写进行实例化 1.3 从其它对象实例化新结构体对象 1.4 使用无命名字段的struct类型 1.5 没有任何字段的structs结构体 1.6 结构体字段的值所有权 结构(struct)是一种自定义数据类型&#xff0c;可以将多个相关类…

存量时代下 用低代码开发平台提升你的CEM

随着人口及流量红利的逐步见顶&#xff0c;我国经济从增量市场迈入存量市场。在充分竞争的存量市场环境下&#xff0c;传统的初级竞争模式无法支撑产业的发展&#xff0c;相反还会让企业陷入持续烧钱的恶性循环中&#xff0c;获客难度的提升无疑加速了体验经济时代的到来&#…

modbus介绍、环境搭建测试与qt下串口/Tcp的demo工程测试

一、modbus的介绍 1.简介 Modbus是一种串行通信协议&#xff0c;于1979年为使用可编程逻辑控制器&#xff08;PLC&#xff09;通信而发表。Modbus已经成为工业领域通信协议的业界标准&#xff08;De facto&#xff09;&#xff0c;并且现在是工业电子设备之间常用的连接方式&a…