JavaScript+html實(shí)現(xiàn)前端頁(yè)面滑動(dòng)驗(yàn)證(2)
本文實(shí)例為大家分享了炫酷的前端頁(yè)面滑動(dòng)驗(yàn)證的具體代碼,供大家參考,具體內(nèi)容如下
分享炫酷的前端頁(yè)面滑動(dòng)驗(yàn)證
前面已經(jīng)發(fā)過(guò)一種,這里再發(fā)一種,只是特效不一樣
還是直接上代碼:
<%@ page contentType="text/html;charset=UTF-8" language="java" %>
<html>
<head>
<title>Title</title>
<style>
/* 滑動(dòng)控件容器,灰色背景 */
#dragContainer {
position: relative;
display: inline-block;
background: #e8e8e8;
width: 300px;
height: 33px;
border: 2px solid #e8e8e8;
}
/* 滑塊左邊部分,綠色背景 */
#dragBg {
position: absolute;
background-color: #7ac23c;
width: 0px;
height: 100%;
}
/* 滑動(dòng)驗(yàn)證容器文本 */
#dragText {
position: absolute;
width: 100%;
height: 100%;
/* 文字水平居中 */
text-align: center;
/* 文字垂直居中,這里不能用百分比,因?yàn)榘俜直仁窍鄬?duì)原始line-height的,而非div高度 */
line-height: 33px;
/* 文本不允許選中 */
user-select: none;
-webkit-user-select: none;
}
/* 滑塊 */
#dragHandler {
position: absolute;
width: 40px;
height: 100%;
cursor: move;
}
/* 滑塊初始背景 */
.dragHandlerBg {
background: #fff no-repeat center url("");
}
/* 驗(yàn)證成功時(shí)的滑塊背景 有√*/
.dragHandlerOkBg {
background: #fff no-repeat center url("");
}
</style>
</head>
<body>
<div id="dragContainer"><!-- 容器初始背景 -->
<div id="dragBg"></div><!-- 綠色背景 -->
<div id="dragText"></div><!-- 滑動(dòng)容器文本 -->
<div id="dragHandler" class="dragHandlerBg"></div>
</div> <!-- 滑塊 滑塊初始背景 -->
</body>
<script>
//加載(事件會(huì)在頁(yè)面加載完成后觸發(fā))
window.onload = function() {
//獲取滑動(dòng)控件容器,灰色背景
var dragContainer = document.getElementById("dragContainer");
//獲取滑塊左邊部分,綠色背景
var dragBg = document.getElementById("dragBg");
//獲取滑動(dòng)驗(yàn)證容器文本
var dragText = document.getElementById("dragText");
//獲取滑塊
var dragHandler = document.getElementById("dragHandler");
//滑塊的最大偏移量 = 滑動(dòng)驗(yàn)證容器文本長(zhǎng)度 - 滑塊長(zhǎng)度
var maxHandlerOffset = dragContainer.clientWidth - dragHandler.clientWidth;
//是否驗(yàn)證成功的標(biāo)記
var isVertifySucc = false;
initDrag();
function initDrag() {
//在滑動(dòng)驗(yàn)證容器文本寫入“拖動(dòng)滑塊驗(yàn)證”
dragText.textContent = "拖動(dòng)滑塊驗(yàn)證";
//給滑塊添加鼠標(biāo)按下監(jiān)聽(tīng)
dragHandler.addEventListener("mousedown", onDragHandlerMouseDown);
}
//選中滑塊
function onDragHandlerMouseDown() {
//鼠標(biāo)移動(dòng)監(jiān)聽(tīng)
document.addEventListener("mousemove", onDragHandlerMouseMove);
//鼠標(biāo)松開(kāi)監(jiān)聽(tīng)
document.addEventListener("mouseup", onDragHandlerMouseUp);
}
//滑塊移動(dòng)
function onDragHandlerMouseMove() {
/*
html元素不存在width屬性,只有clientWidth
offsetX是相對(duì)當(dāng)前元素的,clientX和pageX是相對(duì)其父元素的
*/
//滑塊移動(dòng)量
var left = event.clientX - dragHandler.clientWidth / 2;
//
if(left < 0) {
left = 0;
//如果滑塊移動(dòng)量 > 滑塊的最大偏移量 ,則調(diào)用驗(yàn)證成功函數(shù)
} else if(left > maxHandlerOffset) {
left = maxHandlerOffset;
verifySucc();
}
//滑塊移動(dòng)量
dragHandler.style.left = left + "px";
//綠色背景的長(zhǎng)度
dragBg.style.width = dragHandler.style.left;
}
//松開(kāi)滑塊函數(shù)
function onDragHandlerMouseUp() {
//移除鼠標(biāo)移動(dòng)監(jiān)聽(tīng)
document.removeEventListener("mousemove", onDragHandlerMouseMove);
//移除鼠標(biāo)松開(kāi)監(jiān)聽(tīng)
document.removeEventListener("mouseup", onDragHandlerMouseUp);
//初始化滑塊移動(dòng)量
dragHandler.style.left = 0;
//初始化綠色背景
dragBg.style.width = 0;
}
//驗(yàn)證成功
function verifySucc() {
//成功標(biāo)記,不可回彈
isVertifySucc = false;
//容器文本的文字改為白色“驗(yàn)證通過(guò)”字體
dragText.textContent = "驗(yàn)證通過(guò)";
dragText.style.color = "white";
//驗(yàn)證通過(guò)的滑塊背景
dragHandler.setAttribute("class", "dragHandlerOkBg");
//移除鼠標(biāo)按下監(jiān)聽(tīng)
dragHandler.removeEventListener("mousedown", onDragHandlerMouseDown);
//移除 鼠標(biāo)移動(dòng)監(jiān)聽(tīng)
document.removeEventListener("mousemove", onDragHandlerMouseMove);
//移除鼠標(biāo)松開(kāi)監(jiān)聽(tīng)
document.removeEventListener("mouseup", onDragHandlerMouseUp);
// 匹配成功以后寫入你要跳轉(zhuǎn)的頁(yè)面
//window.location.href="成功頁(yè)面.html" rel="external nofollow" ;
};
}
</script>
</html>
效果如下



以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 使用Vue-scroller頁(yè)面input框不能觸發(fā)滑動(dòng)的問(wèn)題及解決方法
- vue基于better-scroll實(shí)現(xiàn)左右聯(lián)動(dòng)滑動(dòng)頁(yè)面
- vue實(shí)現(xiàn)頁(yè)面切換滑動(dòng)效果
- vue 路由頁(yè)面之間實(shí)現(xiàn)用手指進(jìn)行滑動(dòng)的方法
- 基于Vue實(shí)現(xiàn)頁(yè)面切換左右滑動(dòng)效果
- JavaScript+html實(shí)現(xiàn)前端頁(yè)面滑動(dòng)驗(yàn)證
- JavaScript 獲取滾動(dòng)條位置并將頁(yè)面滑動(dòng)到錨點(diǎn)
- js實(shí)現(xiàn)滑動(dòng)到頁(yè)面底部自動(dòng)加載更多功能
- js/jquery控制頁(yè)面動(dòng)態(tài)加載數(shù)據(jù) 滑動(dòng)滾動(dòng)條自動(dòng)加載事件的方法
- vue/js實(shí)現(xiàn)頁(yè)面自動(dòng)往上滑動(dòng)效果
相關(guān)文章
JS實(shí)現(xiàn)文檔加載完成后執(zhí)行代碼
本文給大家講述的是使用javascript實(shí)現(xiàn)文檔加載完成后再執(zhí)行代碼的方法和示例,非常簡(jiǎn)單實(shí)用,有需要的小伙伴可以參考下。2015-07-07
用javascript獲取任意顏色的更亮或更暗顏色值示例代碼
最近在工作中遇到的一個(gè)需求,發(fā)現(xiàn)網(wǎng)上沒(méi)有相對(duì)應(yīng)的解決方法,索性自己寫一個(gè),所以這篇文章主要給大家介紹了關(guān)于利用javascript獲取任意顏色更亮或更暗顏色值的相關(guān)資料,文中給出了詳細(xì)的示例代碼,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-07-07
利用javascript移動(dòng)div層-javascript 拖動(dòng)層
利用javascript開(kāi)發(fā)在界面上隨意拖動(dòng)以下html code中的div層2009-03-03
Firefox getBoxObjectFor getBoundingClientRect聯(lián)系
Firefox在含有flash的網(wǎng)頁(yè)上提示:不建議使用 getBoxObjectFor() 。 請(qǐng)使用 element.getBoundingClientRect()。2008-10-10
javascript 簡(jiǎn)練的幾個(gè)函數(shù)
看CSDN上別人的代碼,感覺(jué)比較精煉,拿來(lái)主義,需要的朋友可以看下。2009-08-08
利用onresize使得div可以隨著屏幕大小而自適應(yīng)的代碼
javascript 利用onresize使得div可以隨著屏幕大小而自適應(yīng)的代碼2010-01-01
教學(xué)演示-UBB,剪貼板,textRange及其他
[紅色]教學(xué)演示-UBB,剪貼板,textRange及其他...2006-11-11

