html:

<div id="dragContainer">
<div id="dragBg"></div>
<div id="dragText"></div>
<div id="dragHandler" class="dragHandlerBg"></div>
</div>
css:

背景 */
#dragBg {
position: absolute;
background-color: #2f99fb;
width: 0;
height: 100%;
}
/* 滑动验证容器文本 */
#dragText {
position: absolute;
width: 100%;
height: 100%;
/* 文字水平居中 */
text-align: center;
/* 文字垂直居中,这里不能用百分比,因为百分比是相对原始line-height的,而非div高度 */
line-height: 42px;
/* 文本不允许选中 */
user-select: none;
-webkit-user-select: none;
}
/* 滑块 */
#dragHandler {
position: absolute;
width: 40px;
height: 40px;
cursor: move;
}
/* 滑块初始背景 */
.dragHandlerBg {
border: 1px solid #ddd;
background: #fff no-repeat center url("");
}
/* 验证成功时的滑块背景 */
.dragHandlerOkBg{
border: 1px solid #2f99fb;
background: #fff url("../images/toggle.png") no-repeat center;
}

javascript:

window.onload = function() {
var dragContainer = document.getElementById("dragContainer");
var dragBg = document.getElementById("dragBg");
var dragText = document.getElementById("dragText");
var dragHandler = document.getElementById("dragHandler");

//滑块最大偏移量
var maxHandlerOffset = dragContainer.offsetLeft + dragContainer.offsetWidth - dragHandler.offsetWidth;
//是否验证成功的标记
var isVertifySucc = false;
initDrag();

function initDrag() {
dragText.textContent = "拖动滑块验证";
dragHandler.addEventListener("mousedown", onDragHandlerMouseDown);
}

function onDragHandlerMouseDown() {
document.addEventListener("mousemove", onDragHandlerMouseMove);
document.addEventListener("mouseup", onDragHandlerMouseUp);
}

function onDragHandlerMouseMove() {
/*
html元素不存在width属性,只有clientWidth
offsetX是相对当前元素的,clientX和pageX是相对其父元素的
*/
var left = event.clientX - dragHandler.clientWidth / 2;
console.log(event.clientX);
if(left < dragContainer.offsetLeft) {
left = dragContainer.offsetLeft;
} else if(left > maxHandlerOffset) {
left = maxHandlerOffset;
verifySucc();
}
dragHandler.style.left = left - dragContainer.offsetLeft + "px";
dragBg.style.width = dragHandler.style.left;
}

function onDragHandlerMouseUp() {
document.removeEventListener("mousemove", onDragHandlerMouseMove);
document.removeEventListener("mouseup", onDragHandlerMouseUp);
dragHandler.style.left = 0;
dragBg.style.width = 0;
}

//验证成功
function verifySucc() {
isVertifySucc = true;
dragText.textContent = "验证通过";
dragText.style.color = "white";
dragHandler.setAttribute("class", "dragHandlerOkBg");
dragHandler.removeEventListener("mousedown", onDragHandlerMouseDown);
document.removeEventListener("mousemove", onDragHandlerMouseMove);
document.removeEventListener("mouseup", onDragHandlerMouseUp);
}
}

实现样式:




参考:http://blog.csdn.net/chy555chy/article/details/55294147




更多相关文章

  1. 将XML元素反序列化为Java Map
  2. 按下子活动后退按钮后,Android主要活动的元素不响应
  3. Android:如何自动刷新UI上的元素(无需刷新整个屏幕)
  4. dom4j-java-如何获取root中具有特定元素名称的所有元素(父元素或
  5. Selenium InternetExplorerDriver无法找到明显的元素。
  6. java中循环遍历删除List和Set集合中元素的方法
  7. 使用SAX Filter将新元素插入XML文件
  8. java入门---数据结构操作实例之获取链表的元素
  9. Java的Web项目中Web.xml配置文件元素详解

随机推荐

  1. Bash On Ubuntu On Windows折腾记
  2. Java 中的构造函数引用和方法引用
  3. 深入typeclass_Haskell笔记4
  4. 【Java】留下没有基础眼泪的面试题
  5. 类型_Haskell笔记3
  6. 使用 IntelliJ 调试 Java Streams
  7. 六一儿童节,送你一个F字符串
  8. 每周 10 道 Java 面试题:集合类
  9. 学习linux的第5天
  10. 如何使用maven 轻松重构项目