zoukankan      html  css  js  c++  java
  • Jquery数字转盘:

    项目中,在充值流程中,加入了1个抽奖环节,需要转盘显示抽中的虚拟货币。网上找了相关的特效,最后锁定在这个特效上:http://www.jb51.net/jiaoben/319636.html。因为用的是jquery实现的,项目中有引入jquery,不用添加新的js库就很方便的实现。

    整个流程是:用户支付完成后,后台随机产生抽中的数字,传到转盘页面。转盘页面只是负责动态的显示后台产生的数字(而不是页面产生随机数)。那好,前端的工作就变成了接收一个数字,我们这里假定是三位的,两位的数字后端传过来的时候百位上就补零了,如:85补成085;前端负责动态的显示085就醒了。

    UI效果图:

     

    修改下下来的代码:

    <!DOCTYPE html>
    <html>
    <head lang="en">
        <meta charset="UTF-8">
        <title>充值抽奖</title>
        <meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0">
        <meta name="apple-mobile-web-app-capable" content="yes">
        <meta name="apple-mobile-web-app-status-bar-style" content="black">
        <meta name="format-detection" content="telephone=no">
        <link rel="stylesheet" href="../../assets/css/amazeui.min.css?v=1.0">
        <link rel="stylesheet" href="../../assets/css/style1.css?v=1.0">
        <link rel="stylesheet" href="../../assets/css/index.css?v=1.0">
        <style>
    input, button, select, textarea, a:fouse {outline:none}
    li {list-style:none;}
    img {border:none;}
    textarea {resize:none;}
    body {margin:0;font: 12px "微软雅黑"; background: #feecd4;}
    /* === End CSS Reset ========== */
    
    body{
        _expression((document.documentElement.clientWidth||document.body.clientWidth)<950?"950px":"");
    }
    a{
        text-decoration: none;
    }
    .clearfix:after {
        visibility: hidden;
        display: block;
        font-size: 0;
        content: " ";
        clear: both;
        height: 0;
    }
    .clearfix{*zoom:1;}
    
    .container{
        100%;
        margin: 0 auto;
        position: relative;
        /*height: 198px;*/
    }
    
    /* 头部 */
    /*.main{
        background: url("images/main.jpg") no-repeat center;
        background: #feecd4;
        height: 351px;
        _expression((document.documentElement.clientWidth||document.body.clientWidth)<1000?"1000px":"");
    }*/
    .main2{
    	margin:0 auto;
        background: url("../../assets/images/activities/main2-1.png") no-repeat center;
    	300px;
    	height:300px;
    	background-size:300px 300px;
        /*最小宽度*/
    }
    .main3{
        /*background: url("images/main3.jpg") no-repeat center;
        height: 381px;*/
        _expression((document.documentElement.clientWidth||document.body.clientWidth)<1000?"1000px":"");
    }
    .main3-text{
        color:#744b00;
        font-size: 23px;
        font-weight: bold;
        position: absolute;
        left: 74px;
        top: 210px;
    }
    .main3-text2{
        color:#744b00;
        font-size: 14px;
        position: absolute;
        left: 74px;
        top: 254px;
        line-height: 22px;
         867px;
    }
    .main-text{
        position: absolute;
        left: 360px;
        top: 325px;
        color:#b03b01;
        font-size: 16px;
    }
    .main2-text1{
        position: absolute;
        left: 79px;
        top: 45px;
        color:#ffffff;
        font-size: 16px;
    }
    .main2-text2{
        position: absolute;
        left: 69px;
        top: 67px;
        color:#ffffff;
        font-size: 23px;
        font-weight: bold;
    }
    .main2-text2 span{
        color:#ffff00;
    }
    .main2-text3{
        position: absolute;
        left: 69px;
        top: 97px;
        color:#ffffff;
        font-size: 18px;
    }
    .main2-text4{
        position: absolute;
        left: 382px;
        top: 34px;
        color:#ffffff;
        font-size: 18px;
    }
    .main2-text4 span{
        color:#ffe700;
        font-weight: bold;
    }
    .main2-text5{
        position: absolute;
        left: 665px;
        top: 34px;
        color:#ffffff;
        font-size: 18px;
    }
    .main2-text5 span{
        color:#ffe700;
        font-weight: bold;
    }
    .num{
        position: absolute;
        left: 30px;
        top: 95px;
         72px;
        height: 112px;
        overflow: hidden;
    }
    .num-con{
        position: relative;
        top:-724px;
    }
    .num-img{
        background: url("../../assets/images/activities/num-1.png") no-repeat;
         72px;
        height: 744px;
        margin-bottom: 4px;
    }
    .num2{
        left: 114px;
    }
    .num3{
        left: 198px;
    }
    
    .main3-btn{
         307px;
        height: 95px;
        position: absolute;
        left: 313px;
        top: -290px;
        cursor: pointer;
    }
    </style>
    </head>
    <body class="bg-home" style="">
    </header>
    <body>
    <section class="activities">
    	<div class="am-padding-sm text-center font-16 content1" style="padding-top:1.5rem;">
        	<img style="100%;"src="../../assets/images/activities/word-2.png"/>
           	<div class="font-16 font-bold" style="left:53%;bottom:10%;position:absolute;color:#fff601">200-800</div>
        </div>
    	
        <!--转盘-->
        <div style="margin-top:6%;">
        	<div class="main2">
    	<div class="container">
    		<div class="num num1">
    			<div class="num-con num-con1">
    				<div class="num-img"></div>
    				<div class="num-img"></div>
    			</div>
    		</div>
    		<div class="num num2">
    			<div class="num-con num-con2">
    				<div class="num-img"></div>
    				<div class="num-img"></div>
    			</div>
    		</div>
    		<div class="num num3">
    			<div class="num-con num-con3">
    				<div class="num-img"></div>
    				<div class="num-img"></div>
    			</div>
    		</div>
    	</div>
    </div>
        <!--点击抽奖按钮-->
        <div  style="margin:5% auto 0 auto;250px;" id="lottery">
        	<img style="100%;" src="../../assets/images/activities/lottery.png"/>
        </div>
        <!--返回个人中心-->
         <div  style="margin:5% auto 0 auto;250px;" id="lottery">
        	<img style="100%;" src="../../assets/images/activities/personal.png"/>
        </div>
        <!--蒙版图层-->
        <section>
       	<div id="masking-bg"> 
        </div> 
        <div id="masking-layer">
        	
            <div class="masking-banner" onclick="" style="270px;left:50%;top:20%; margin-left:-135px;">
            	<img class="img-bg" src="../../assets/images/activities/lottery-notice.png"/>
                <div class="font-25 font-white" style="top:64%;">X<span id="money">500</span></div>
                <div style="200px;position:absolute;z-index:2000;bottom:0;left:50%; margin-left:-100px;padding-top:8%;" onclick="window.location.href=''">
                	<img  style = "100%;"src="../../assets/images/activities/lixy.png"/>
                </div>
                <div  class="close1" onclick="closeMasking()" style="40px;left:230px;top:0;">
           			<img  style="100%;" src="../../assets/images/common/X-1.png"/>
            	</div>
            </div> 
         </div>
        </section>
    
    </section>  
        
    <script src="../../assets/js/jquery.min.js"></script>
    <script> 		
    	//设置body高度等于手机屏幕高度
    	$(".activities").height($(window).height());
    </script>
    <script type="text/javascript">
    	$("#lottery").click(function () {
    			reset();
    			letGo();
    	});
    
    	var flag=false;
    	var index=0;
    	var TextNum1
    	var TextNum2
    	var TextNum3
    	
    	//后台传来的随机的金额,数字字符串格式
    	var money = "341";
    	function letGo(){
    
    		TextNum1=money[0];
    		TextNum2=money[1];
    		TextNum3=money[2];
    		//位置数组 比如arr[0]就是0所在的位置
    		var arr= [-724,-798.4,-872.8,-947.2,-1021.6,-1096,-1170.4,-1244.8,-1319.2,-646.3];
    		//百位
    		var num1=arr[TextNum1];//在这里随机
    		var num2=arr[TextNum2];
    		var num3=arr[TextNum3];
    		
    		//百位
    		function do1(){
    		$(".num-con1").animate({"top":-1140},1500,"linear", function () {
    			$(this).css("top",0).animate({"top":num1},1500,"linear");
    			setTimeout(function(){showMasking(money)},2000);
    		});
    	
    		}
    		
    		//十位
    		function do2(){
    		$(".num-con2").animate({"top":-1140},1000,"linear", function () {
    			$(this).css("top",0).animate({"top":num2},1000,"linear");
    		});
    		}
    		
    		//个位
    		function do3(){
    		$(".num-con3").animate({"top":-1492},500,"linear", function () {
    			$(this).css("top",0).animate({"top":num3},500,"linear");
    		});
    		}
    		setTimeout(do3,0);
    		setTimeout(do2,0);
    		setTimeout(do1,0);
    	}
    
    	function reset(){
    		$(".num-con1,.num-con2,.num-con3").css({"top":-724});
    	}
    	
    	$('#masking-layer').height($(window).height());
        function showMasking(text){
    		$('#masking-bg').css('display','block');
    		$('#masking-layer').css('display','block');
    		$('#money').text(text)
        }
        
    	function closeMasking(){
    		$('#masking-bg').css('display','none');
    		$('#masking-layer').css('display','none');
        }
        
    </script>
    </script>
    </body>
    </html>
    

      上面的代码并不全,因为引入的3个css里的样式没区出来,相信你已经看懂怎么实现了。

  • 相关阅读:
    spark 随机森林算法案例实战
    AngularJS 下拉列表demo
    机器学习案例学习【每周一例】之 Titanic: Machine Learning from Disaster
    sklearn中的数据预处理----good!! 标准化 归一化 在何时使用
    kaggle 中使用ipython
    机器学习中的数据不平衡问题----通过随机采样比例大的类别使得训练集中大类的个数与小类相当,或者模型中加入惩罚项
    机器学习 数据量不足问题----1 做好特征工程 2 不要用太多的特征 3 做好交叉验证 使用线性svm
    [029] 微信公众帐号开发教程第5篇-各种消息的接收与响应(转)
    [028] 微信公众帐号开发教程第4篇-消息及消息处理工具的封装(转)
    微信公众帐号开发教程第3篇-开发模式启用及接口配置(转)
  • 原文地址:https://www.cnblogs.com/xiaochongchong/p/5577090.html
Copyright © 2011-2022 走看看