html滑动解锁,js实现滑动解锁效能(PC+Moblie)

本文详细介绍了如何使用JavaScript实现一个适用于PC和移动端的滑动解锁功能。通过监听鼠标和触摸事件,结合CSS样式,创建了一个从左到右滑动以解锁的交互组件。当滑动到指定位置时,会触发解锁效果并显示相应的提示信息。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

js实现滑动解锁功能(PC+Moblie)

实现效果:

152628103.png

css样式代码略。

html代码:

页面上导入了jquery.mobile 、jquery

Slide to confirm I am human!

js代码:

window.onload = function () {

var slider1 = new Slider();

slider1.Init();

///屏幕大小发生改变时触发

$(window).resize(function () {

slider1.HanderIn();

slider1.HanderOut();

});

}

//滑动条对象

function Slider(swipestart, min, max, index, IsOk, lableIndex) {

var _self = this;

//是否开始滑动

_self.swipestart = swipestart;

//最小值

_self.min = min;

//最大值

_self.max = max;

//当前滑动条所处的位置

_self.index = index;

//是否滑动成功

_self.IsOk = IsOk;

//鼠标在滑动按钮的位置

_self.lableIndex = lableIndex;

}

//初始化

Slider.prototype.Init = function () {

var _self = this;

$("#label").on("mousedown", function (event) {

var e = event || window.event;

_self.lableIndex = e.clientX - this.offsetLeft;

_self.HanderIn();

});

$("#pageSlide").on("mousemove", function (event) {

_self.HanderMove(event);

});

$(document).on("mouseup", function (event) {

_self.HanderOut();

});

$("#label").on("touchstart", function (event) {

var e = event || window.event;

_self.lableIndex = e.originalEvent.pageX - this.offsetLeft;

_self.HanderIn();

});

$("#pageSlide").on("touchmove", function (event) {

_self.HanderMove(event, "mobile");

});

$(document).on("touchend", function (event) {

_self.HanderOut();

});

}

//鼠标/手指接触滑动按钮

Slider.prototype.HanderIn = function () {

var _self = this;

_self.swipestart = true;

_self.min = 0;

_self.max = $("#slider").width();

}

//鼠标/手指移出

Slider.prototype.HanderOut = function () {

var _self = this;

//停止

_self.swipestart = false;

_self.Move();

}

//鼠标/手指移动

Slider.prototype.HanderMove = function (event, type) {

var _self = this;

if (_self.swipestart) {

event.preventDefault();

var event = event || window.event;

if (type == "mobile") {

_self.index = event.originalEvent.pageX - _self.lableIndex;

} else {

_self.index = event.clientX - _self.lableIndex;

}

_self.Move();

}

}

//鼠标/手指移出

Slider.prototype.Move = function () {

var _self = this;

$(".warn").text("index:" + _self.index + ", max" + _self.max + ",lableIndex:" + _self.lableIndex + ",value:" + $("#captcha").val() + " date:" + new Date().getUTCDate());

if ((_self.index + 20) >= _self.max) {

_self.index = _self.max - 20;

}

if (_self.index < 0) {

_self.index = _self.min;

}

$(".label").css("left", _self.index + "px");

if (_self.index == (_self.max - 20)) {

//停止

_self.swipestart = false;

_self.IsOk = true;//解锁

$("#captcha").val(1);

var style = {"filter": "alpha(opacity=1)",

"-moz-opacity": "1", "opacity": "1"}

$(".ui-btn.ui-input-btn.ui-corner-all.ui-shadow").css(style);

$("#slider").css("background-color", "#E5EE9F");

$("#lableTip").text("Thank You!");

} else {

_self.IsOk = false;//未解锁

$("#captcha").val(0);

var style = { "filter": "alpha(opacity=0.2)",

"-moz-opacity": "0.2", "opacity": "0.2"}

$(".ui-btn.ui-input-btn.ui-corner-all.ui-shadow").css(style);

$("#slider").css("background-color", "#FDEB9C");

$("#lableTip").text("Slide to confirm I am human!");

}

}

效果实现:

152628104.jpg

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值