jQuery拼图滑块验证

html 部分

 1 <div class="yz">
 2     <div class="img">
 3         <img class="bg" src="1.png" alt="">                                        
 4         <img class="bg-part" src="1a.png" alt="">  
 5         <div></div>
 6     </div>
 7     <div class="hd">
 8         <p>按住左边滑块,拖动完成上方拼图</p>
 9         <div class="hd-bg"></div>
10         <div class="hk"></div>
11     </div>
12 </div>
13 
14 <!-- 为了验证成功的html部分 -->
15 <div class="aaa"></div>

 

css 部分

 1 *{margin:0;padding: 0}
 2 .yz{width: 310px;margin: 20px auto;}
 3 .img{width: 310px;height: 155px;position: relative;}
 4 .img .bg{width: 100%;}
 5 .img .bg-part{position: absolute;top: 0;left: 0;}
 6 .img div{position: absolute;top: 0;right: 0;width: 24px;height: 24px;background-image: url(bg.png);background-position: -6px -113px;cursor: pointer;}
 7 .hd{position: relative;width: 310px;height: 30px;margin-top: 10px;background: #ECE4DD;border-radius: 20px;}
 8 .hd p{height: 30px;line-height: 30px;margin-left:50px;}
 9 .hd .hd-bg{width: 310px;height: 30px;position: absolute;top: 0;left: 0;z-index: 1;}
10 .hd .hk{position: absolute;width: 38px;height: 38px;top: -3px;left: 0;background-image: url(bg.png);background-position: 0 0;z-index: 10;cursor: pointer;}
11 .hd .hk.active{background-position: 0 -37px;}
12 .hd .hk.success{background-position: 0 -74px;}
13 
14 //为了验证成功的样式
15 .aaa{font-size: 24px;font-weight: bold;color: #f00;text-align: center;}

 

jquery 部分

 1 var fixedLeft;
 2 var isSuccess = false;
 3 var isSlide = true;
 4 $(function(){
 5     renew();
 6     $(".hk").mousedown(function(e){
 7         if(isSlide == false){
 8             return;
 9         }
10         var _this = $(this);
11         //e.pageX 鼠标距离整个页面左边的距离
12         var pageX = e.pageX;    //pageX 鼠标最开始的位置
13         //滑块所能移动的总长度
14         var distance = $(".hd").width - $(_this).width();
15         $(this).addClass("active");
16         $(document).mousemove(function(e){
17             //鼠标距离最开始按下的点所移动的距离
18             var x = e.pageX - pageX;
19             if(x < 0){
20                 x = 0;
21             }else if(x > distance){
22                 x = distance;
23             }
24             if(x >= fixedLeft - 2 && x <= fixedLeft + 2){
25                 isSuccess = true;
26             }else{
27                 isSuccess = false;
28             }
29             $(_this).css("left",x);
30             $(".bg-part").css("left",x);
31         })
32         $(document).mouseup(function() {
33             if(isSuccess){
34                 $(_this).removeClass("active").addClass("success").css("left",fixedLeft);
35                 $(".bg-part").css("left",fixedLeft);
36                 isSlide = false;
37                 // 为了验证成功的js
38                 $(".aaa").text("成功了");
39             }else{
40                 $(_this).removeClass("active").css("left","0");
41                 $(".bg-part").css("left","0");
42             }
43             $(document).off('mousemove');
44         });
45     })
46     $(".img").find("div").click(function(){
47         renew();
48     })
49     
50 })
51 function renew(){
52     // 为了验证成功的js
53     $(".aaa").text("");
54     isSuccess = false;
55     isSlide = true;
56     $(".hk").removeClass("active").removeClass("success").css("left","0");
57     $(".bg-part").css("left","0");
58     var num = Math.floor(Math.random()*10);
59     $(".img").find(".bg").attr("src",num+".png");
60     $(".img").find(".bg-part").attr("src",num+"a.png");
61     switch(num){ 
62         case 0:
63             fixedLeft = 117;
64             break;
65         case 1:
66             fixedLeft = 167;
67             break;
68         case 2:
69             fixedLeft = 125;
70             break;
71         case 3:
72             fixedLeft = 157;
73             break;
74         case 4:
75             fixedLeft = 71;
76             break;
77         case 5:
78             fixedLeft = 117;
79             break;
80         case 6:
81             fixedLeft = 143;
82             break;
83         case 7:
84             fixedLeft = 144;
85             break;
86         case 8:
87             fixedLeft = 182;
88             break;
89         default:
90             fixedLeft = 125;
91     }
92 }

 

效果图:

  在项目上,图片是后端实现提供的,图片的名称及补的图片所需要移动的距离,需要后端提供,此处只是单纯前端实现,所以,通过随机的方式,对10张图片进行随机选择,因此,命名方式就比较随便。所有的图片(总共20张图片)都是从https://www.jq22.com/jquery-info21851这里随机弄了补的图和背景图各10张保存的,至于成功和刷新等图片,是根据https://www.jq22.com/jquery-info20476和https://www.jq22.com/jquery-info21851的图标图片,用ps改的,图标图片附在最后面。

 

文章参考:https://www.jq22.com/jquery-info20476

        https://www.jq22.com/jquery-info21851

        https://www.jq22.com/webqd1345

 

图标图片:

posted @ 2021-03-11 17:02  傅丹辰cds  阅读(1571)  评论(0编辑  收藏  举报