实现javaweb滑块验证码的代码
时间: 2023-10-09 16:15:27 浏览: 38
好的,以下是一个简单的实现javaweb滑块验证码的代码,仅供参考:
HTML代码:
```HTML
<!-- 滑块验证 -->
<div class="slide-verify">
<span class="drag-icon">请按住滑块拖动</span>
<div class="drag">
<div class="drag-bg"></div>
<div class="handler bg-primary"></div>
</div>
<span class="text-default"></span>
</div>
```
CSS样式:
```CSS
/* 滑块验证 */
.slide-verify {
position: relative;
height: 54px;
line-height: 54px;
width: 280px;
margin: 0 auto;
background-color: #f2f2f2;
text-align: center;
}
.slide-verify .text-default {
display: none;
}
.slide-verify .drag {
overflow: hidden;
height: 56px;
position: relative;
cursor: pointer;
}
.slide-verify .drag .drag-bg {
position: relative;
z-index: 50;
height: 56px;
width: 220px;
border-radius: 28px;
background-color: #d9d9d9;
}
.slide-verify .drag .handler {
position: absolute;
left: 0;
top: 0;
cursor: pointer;
height: 56px;
width: 56px;
border-radius: 28px;
background-color: #fff;
line-height: 56px;
text-align: center;
}
.slide-verify .drag .handler:after {
content: "\f0cd";
font-family: FontAwesome;
font-size: 24px;
color: #777;
}
.slide-verify .drag:hover .handler {
background-color: #d9d9d9;
}
.slide-verify .drag.active .drag-bg {
background-color: #1AB394;
}
.slide-verify .drag.active .handler:after {
content: "\f00c";
color: #fff;
}
```
JS代码:
```JS
$(function() {
var $slider = $('.slide-verify');
var $handler = $slider.find('.handler');
var $drag_bg = $slider.find('.drag-bg');
var $text_default = $slider.find('.text-default');
var max_left = $slider.width() - $handler.width();
var is_ok = false;
$handler.mousedown(function() {
$(document).on('mousemove.slide', function(evt) {
var left = evt.clientX - $slider.offset().left - $handler.width();
if (left < 0) {
left = 0;
}
if (left > max_left) {
left = max_left;
}
$handler.css({left: left});
$drag_bg.css({width: left});
return false;
});
$(document).on('mouseup.slide', function(evt) {
$(document).off('mousemove.slide mouseup.slide');
var left = $handler.offset().left - $slider.offset().left - $handler.width();
if (left < 0) {
left = 0;
}
if (left >= max_left) {
is_ok = true;
// 验证成功后,可执行其他操作
$handler.addClass('bg-success').css({left: max_left});
$drag_bg.addClass('bg-success').addClass('rounded-right');
$text_default.text('验证通过!').css({color: '#1AB394', display: 'inline'});
} else {
is_ok = false;
$handler.animate({left: 0});
$drag_bg.animate({width: 0});
}
return false;
});
return false;
});
});
```
以上代码仅供参考,如果您有任何问题或者需要完整的代码实现,请与专业的开发人员进行联系,以获得更好的帮助。