侯体宗的博客
  • 首页
  • Hyperf版
  • beego仿版
  • 人生(杂谈)
  • 技术
  • 关于我
  • 更多分类
    • 文件下载
    • 文字修仙
    • 中国象棋ai
    • 群聊
    • 九宫格抽奖
    • 拼图
    • 消消乐
    • 相册

纯CSS3大转盘抽奖示例代码(响应式、可配置)

前端  /  管理员 发布于 7年前   198

源于前段时候微信小程序最初火爆公测时段,把以前用 Canvas 实现的大转盘抽奖移植成微信小程序,无奈当时小程序对 Canvas 支持不够完善,只好降低用 CSS3 实现。虽然比不上 Canvas 绘图的绚丽,但也总算完成了一个抽奖的 Demo,详见:http://xiazai..net.cn/201701/yuanma/wechat-canvas_jb51.rar

事后想起,CSS3 实现也并不是无有益处,比如简单、快捷、调试方便、渲染想来也是要比 Canvas 要高效的,更重要的一点是支持媒体查询,大转盘也可以做成响应式的。因此抽空整理,用纯 CSS3 实现一个大转盘抽奖 Demo 并记录下来。

如果有类似需求并不想麻烦了解细节,可移步这里——Canvas 完整的大转盘抽奖项目(可以直接拿来用)http://xiazai..net.cn/201701/yuanma/canvas_jb51.rar

以下就直接贴代码了。

代码

HTML

<section class="gb-wheel-container" id="gbWheel">    <div class="gb-wheel-content gb-wheel-run">        <ul class="gb-wheel-line"></ul>        <div class="gb-wheel-list"></div>    </div>    <a href="javascript:;" class="gb-wheel-btn" id="gbLottery">抽奖</a>     </section>

JS

(function() {    // 奖品配置    var awards = [{'index': 0, 'text': '耳机' , 'name': 'icono-headphone'},{'index': 1, 'text': 'iPhone' , 'name': 'icono-iphone'},{'index': 2, 'text': '相机' , 'name': 'icono-camera'},{'index': 3, 'text': '咖啡杯' , 'name': 'icono-cup'},{'index': 4, 'text': '日历', 'name': 'icono-calendar'},{'index': 5, 'text': '键盘', 'name': 'icono-keyboard'}        ],        len = awards.length,        turnNum = 1 / len;  // 文字旋转 turn 值    var gbWheel = $('gbWheel'),        lineList = gbWheel.querySelector('ul.gb-wheel-line'),        itemList = gbWheel.querySelector('.gb-wheel-list'),        lineListHtml = [],        itemListHtml = [];    var transform = preTransform();    awards.forEach(function(v, i, a) {        // 分隔线        lineListHtml.push('<li class="gb-wheel-litem" style="' + transform + ': rotate('+ (i * turnNum + turnNum / 2) +'turn)"></li>');        // 奖项        itemListHtml.push('<div class="gb-wheel-item">');        itemListHtml.push('<div class="gb-wheel-icontent" style="' + transform + ': rotate('+ (i * turnNum) +'turn)">');        itemListHtml.push('<p class="gb-wheel-iicon">');        itemListHtml.push('<i class="'+v.name+'"></i>');        itemListHtml.push('</p>');        itemListHtml.push('<p class="gb-wheel-itext">');        itemListHtml.push(v.text);        itemListHtml.push('</p>');        itemListHtml.push('</div>');        itemListHtml.push('</div>');    });   lineList.innerHTML = lineListHtml.join('');    itemList.innerHTML = itemListHtml.join('');    function $(id) {        return document.getElementById(id);    };    // 旋转    var i = 0;    $('gbLottery').onclick = function() {        i++;        gbWheel.querySelector('.gb-wheel-content').style = transform + ': rotate('+ i * 3600 +'deg)';      }    // transform兼容    function preTransform() {        var cssPrefix,        vendors = {          '': '',          Webkit: 'webkit',          Moz: '',          O: 'o',          ms: 'ms'        },        testEle = document.createElement('p'),        cssSupport = {};         // 嗅探特性        Object.keys(vendors).some(function(vendor) {if (testEle.style[vendor + (vendor ? 'T' : 't') + 'ransform'] !== undefined) {  cssPrefix = vendor ? '-' + vendor.toLowerCase() + '-' : '';  return true;}        });      function normalizeCss(name) {        name = name.toLowerCase();        return cssPrefix ? cssPrefix + name : name;      }      cssSupport = {        transform: normalizeCss('Transform'),      }      return cssSupport.transform;    }}());

CSS

html {    font-size: 10px}.gb-wheel-container ul,.gb-wheel-container li,.gb-wheel-container p {    margin: 0;    padding: 0}.gb-wheel-container ul,.gb-wheel-container li {    list-style: none}.gb-wheel-container {    margin: 0 auto;    position: relative;    width: 30rem;    height: 30rem;    border-radius: 50%;    box-shadow: 0 2px 3px #333, 0 0 2px #000;    overflow: hidden}.gb-wheel-content {    position: absolute;    left: 1rem;    top: 1rem;    z-index: 2;    width: 28rem;    height: 28rem;    box-sizing: border-box;    border-radius: inherit;    background-clip: padding-box;    background: -webkit-radial-gradient(rgba(100, 100, 100, 0.1) 15%, transparent 16%) 0 0,      -webkit-radial-gradient(rgba(100, 100, 100, 0.1) 15%, transparent 16%) 8px 8px,    -webkit-radial-gradient(rgba(255, 255, 255, 0.1) 15%, transparent 20%) 0 1px,  -webkit-radial-gradient(rgba(255, 255, 255, 0.1) 15%, transparent 20%) 8px 9px;    background: radial-gradient(rgba(100, 100, 100, 0.1) 15%, transparent 16%) 0 0,    radial-gradient(rgba(100, 100, 100, 0.1) 15%, transparent 16%) 8px 8px,   radial-gradient(rgba(255, 255, 255, 0.1) 15%, transparent 20%) 0 1px,   radial-gradient(rgba(255, 255, 255, 0.1) 15%, transparent 20%) 8px 9px;    background-color: #ffcb3f;    background-size: 12px 14px}.gb-wheel-content:before {    content: ' ';    position: absolute;    left: -1rem;    top: -1rem;    z-index: -1;    width: 28rem;    height: 28rem;    border-radius: inherit;    border: 1rem solid #E44025;    box-shadow: 0 0 2px 2px rgba(0, 0, 0, 0.2) inset}.gb-wheel-list {    position: absolute;    left: 0;    top: 0;    width: inherit;    height: inherit;    z-index: 9999}.gb-wheel-item {    position: absolute;    left: 0;    top: 0;    width: 100%;    height: 100%;    color: #e4370e;    font-weight: bold;    text-shadow: 0 1px 1px rgba(255, 255, 255, 0.6)}.gb-wheel-icontent {    position: relative;    display: block;    padding-top: 1.5rem;    margin: 0 auto;    text-align: center;    -webkit-transform-origin: 50% 14rem;    -ms-transform-origin: 50% 14rem;    transform-origin: 50% 14rem}.gb-wheel-itext {    font-size: 1.4rem;    font-weight: lighter}.gb-wheel-iicon [class*=icono-] {    color: #e4370e}.gb-wheel-line {    position: absolute;    left: 0;    top: 0;    width: inherit;    height: inherit;    z-index: 99}.gb-wheel-litem {    position: absolute;    left: 14rem;    top: 0;    width: 1px;    height: 14rem;    background-color: rgba(228, 55, 14, 0.6);    overflow: hidden;    -webkit-transform-origin: 50% 14rem;    -ms-transform-origin: 50% 14rem;    transform-origin: 50% 14rem}.gb-wheel-btn {    position: absolute;    left: 11rem;    top: 11rem;    z-index: 400;    width: 8rem;    height: 8rem;    border-radius: 50%;    color: #F4E9CC;    background-color: #E44025;    line-height: 8rem;    text-align: center;    font-size: 2rem;    text-shadow: 0 -1px 1px rgba(0, 0, 0, 0.6);    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.6), 0 0 5px 4px rgba(0, 0, 0, 0.2) inset;    text-decoration: none}a.gb-wheel-btn {    border-bottom: none}.gb-wheel-btn::after {    position: absolute;    content: '';    left: 2.5rem;    top: -1rem;    width: 3rem;    height: 3rem;    background-color: #E44025;    -webkit-transform: rotate(45deg);    -ms-transform: rotate(45deg);    transform: rotate(45deg);    box-shadow: 0 3px 5px rgba(0, 0, 0, 0.6), 0 0 5px 4px rgba(0, 0, 0, 0.2) inset}.gb-wheel-btn.disabled,.gb-wheel-btn.disabled::after {    pointer-events: none;    background: #B07A7B;    color: #ccc}.gb-wheel-run {    -webkit-transition: transform 6s ease;    transition: transform 6s ease}@media only screen and (min-width: 320px) {    html {        font-size: 10px    }}@media only screen and (min-width: 375px) {    html {        font-size: 11.71875px    }}@media only screen and (min-width: 480px) {    html {        font-size: 15px    }}

项目

demo下载地址:demo

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。


  • 上一条:
    纯CSS3实现扇形动画菜单(简化版)实例源码
    下一条:
    浅析CSS3中鲜为人知的属性:-webkit-tap-highlight-color
  • 昵称:

    邮箱:

    0条评论 (评论内容有缓存机制,请悉知!)
    最新最热
    • 分类目录
    • 人生(杂谈)
    • 技术
    • linux
    • Java
    • php
    • 框架(架构)
    • 前端
    • ThinkPHP
    • 数据库
    • 微信(小程序)
    • Laravel
    • Redis
    • Docker
    • Go
    • swoole
    • Windows
    • Python
    • 苹果(mac/ios)
    • 相关文章
    • 使用 Alpine.js 排序插件对元素进行排序(0个评论)
    • 在js中使用jszip + file-saver实现批量下载OSS文件功能示例(0个评论)
    • 在vue中实现父页面按钮显示子组件中的el-dialog效果(0个评论)
    • 使用mock-server实现模拟接口对接流程步骤(0个评论)
    • vue项目打包程序实现把项目打包成一个exe可执行程序(0个评论)
    • 近期文章
    • 在go+gin中使用"github.com/skip2/go-qrcode"实现url转二维码功能(0个评论)
    • 在go语言中使用api.geonames.org接口实现根据国际邮政编码获取地址信息功能(1个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf分页文件功能(0个评论)
    • gmail发邮件报错:534 5.7.9 Application-specific password required...解决方案(0个评论)
    • 欧盟关于强迫劳动的规定的官方举报渠道及官方举报网站(0个评论)
    • 在go语言中使用github.com/signintech/gopdf实现生成pdf文件功能(0个评论)
    • Laravel从Accel获得5700万美元A轮融资(0个评论)
    • 在go + gin中gorm实现指定搜索/区间搜索分页列表功能接口实例(0个评论)
    • 在go语言中实现IP/CIDR的ip和netmask互转及IP段形式互转及ip是否存在IP/CIDR(0个评论)
    • PHP 8.4 Alpha 1现已发布!(0个评论)
    • 近期评论
    • 122 在

      学历:一种延缓就业设计,生活需求下的权衡之选中评论 工作几年后,报名考研了,到现在还没认真学习备考,迷茫中。作为一名北漂互联网打工人..
    • 123 在

      Clash for Windows作者删库跑路了,github已404中评论 按理说只要你在国内,所有的流量进出都在监控范围内,不管你怎么隐藏也没用,想搞你分..
    • 原梓番博客 在

      在Laravel框架中使用模型Model分表最简单的方法中评论 好久好久都没看友情链接申请了,今天刚看,已经添加。..
    • 博主 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 @1111老铁这个不行了,可以看看近期评论的其他文章..
    • 1111 在

      佛跳墙vpn软件不会用?上不了网?佛跳墙vpn常见问题以及解决办法中评论 网站不能打开,博主百忙中能否发个APP下载链接,佛跳墙或极光..
    • 2016-10
    • 2016-11
    • 2017-06
    • 2017-07
    • 2017-08
    • 2017-09
    • 2017-10
    • 2017-11
    • 2018-03
    • 2018-04
    • 2018-05
    • 2018-06
    • 2018-09
    • 2018-11
    • 2018-12
    • 2019-02
    • 2020-03
    • 2020-04
    • 2020-05
    • 2020-06
    • 2021-04
    • 2021-05
    • 2021-07
    • 2021-08
    • 2021-09
    • 2021-10
    • 2021-11
    • 2022-08
    • 2022-09
    • 2022-10
    • 2022-11
    • 2022-12
    • 2023-01
    • 2023-02
    • 2023-03
    • 2023-04
    • 2023-05
    • 2023-06
    • 2023-07
    • 2023-09
    • 2023-10
    • 2023-11
    • 2023-12
    • 2024-01
    • 2024-02
    • 2024-03
    • 2024-04
    Top

    Copyright·© 2019 侯体宗版权所有· 粤ICP备20027696号 PHP交流群

    侯体宗的博客