123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262 |
- $(document).ready(function () {
- (function (doc, win) {
- var docEl = doc.documentElement,
- resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize',
- recalc = function () {
- var clientWidth = docEl.clientWidth;
- if (!clientWidth) return;
- if (clientWidth >= 750) {
- docEl.style.fontSize = '100px';
- } else {
- docEl.style.fontSize = 100 * (clientWidth / 750) + 'px';
- }
- };
- if (!doc.addEventListener) return;
- win.addEventListener(resizeEvt, recalc, false);
- doc.addEventListener('DOMContentLoaded', recalc, false);
- })(document, window);
- (function (global, factory) {
- typeof exports === 'object' && typeof module !== 'undefined' ? module.exports = factory() :
- typeof define === 'function' && define.amd ? define(factory) :
- (window.slideVerifyPlug = factory());
- }(this, (function () {
- 'use strict';
- var SlideVerify = function (ele, opt) {
- this.$ele = $(ele);
- //默认参数
- this.defaults = {
- initText: '请按住滑块,拖动到最右边',
- sucessText: '验证通过',
- getSuccessState: function () {
- }
- }
- this.settings = $.extend({}, this.defaults, opt);
- this.touchX = 0;
- this.slideFinishState = false;
- this.init();
- }
- SlideVerify.prototype = {
- constructor: SlideVerify,
- init: function () {
- var _this = this;
- _this.initDom();
- _this.initStyle();
- _this.initEle();
- _this._mousedown();
- _this._mouseup();
- _this._touchstart();
- _this._touchmove();
- _this._touchend();
- },
- initDom: function () {
- var html = $(
- '<div class="drag-progress dragProgress">' +
- '</div>' +
- '<span class="drag-btn dragBtn">' +
- '</span>' +
- '<span class="fix-tips fixTips">' +
- this.settings.initText +
- '</span>' +
- '<span class="verify-msg sucMsg">' +
- this.settings.sucessText +
- '</span>');
- this.$ele.append(html);
- },
- initStyle: function () {
- if (this.settings.wrapWidth) {
- this.$ele.css({
- 'width': this.settings.wrapWidth
- })
- } else {
- this.$ele.css({
- 'width': '100%'
- })
- }
- },
- initEle: function () {
- this.slideBtn = this.$ele.find('.dragBtn');
- this.slideProEle = this.$ele.find('.dragProgress');
- this.slideSucMsgEle = this.$ele.find('.sucMsg');
- this.slideFixTipsEle = this.$ele.find('.fixTips');
- this.maxSlideWid = this.calSlideWidth();
- },
- _mousedown: function () {
- var _this = this;
- var ifThisMousedown = false;
- _this.slideBtn.on('mousedown', function (e) {
- var distenceX = e.pageX;
- e.preventDefault();
- if (_this.slideFinishState || _this.ifAnimated()) {
- return false;
- }
- ifThisMousedown = true;
- $(document).mousemove(function (e) {
- if (!ifThisMousedown) {
- return false;
- }
- var curX = e.pageX - distenceX;
- if (curX >= _this.maxSlideWid) {
- _this.setDragBtnSty(_this.maxSlideWid);
- _this.setDragProgressSty(_this.maxSlideWid);
- _this.cancelMouseMove();
- _this.slideFinishState = true;
- if (_this.settings.getSuccessState) {
- _this.settings.getSuccessState(_this.slideFinishState);
- }
- _this.successSty();
- } else if (curX <= 0) {
- _this.setDragBtnSty('0');
- _this.setDragProgressSty('0');
- } else {
- _this.setDragBtnSty(curX);
- _this.setDragProgressSty(curX);
- }
- })
- $(document).mouseup(function () {
- if (!ifThisMousedown) {
- return false;
- }
- ifThisMousedown = false;
- if (_this.slideFinishState) {
- _this.cancelMouseMove();
- return false;
- } else {
- _this.failAnimate();
- _this.cancelMouseMove();
- }
- });
- })
- },
- _mouseup: function () {
- },
- _touchstart: function () {
- var _this = this;
- _this.slideBtn.on('touchstart', function (e) {
- _this.touchX = e.originalEvent.targetTouches[0].pageX;
- if (_this.slideFinishState || _this.ifAnimated()) {
- // _this.cancelTouchmove();
- return false;
- }
- })
- },
- _touchmove: function () {
- var _this = this;
- _this.slideBtn.on('touchmove', function (e) {
- e.preventDefault();
- var curX = e.originalEvent.targetTouches[0].pageX - _this.touchX;
- if (curX >= _this.maxSlideWid) {
- _this.setDragBtnSty(_this.maxSlideWid);
- _this.setDragProgressSty(_this.maxSlideWid);
- _this.cancelTouchmove();
- _this.successSty();
- _this.slideFinishState = true;
- if (_this.settings.getSuccessState) {
- _this.settings.getSuccessState(_this.slideFinishState);
- }
- _this.slideFinishState = true;
- } else if (curX <= 0) {
- _this.setDragBtnSty('0');
- _this.setDragProgressSty('0');
- } else {
- _this.setDragBtnSty(curX);
- _this.setDragProgressSty(curX);
- }
- })
- },
- _touchend: function () {
- var _this = this;
- _this.slideBtn.on('touchend', function () {
- if (_this.slideFinishState) {
- _this.cancelTouchmove();
- return false;
- } else {
- _this.failAnimate();
- }
- })
- },
- getDragBtnWid: function () {//获取滑块的宽度,
- return parseInt(this.slideBtn.width());
- },
- getDragWrapWid: function () {//获取 本容器的的宽度,以防万一
- return parseFloat(this.$ele.outerWidth());
- },
- calSlideWidth: function () {
- var _this = this;
- return _this.getDragWrapWid() - _this.getDragBtnWid()
- },
- ifAnimated: function () {//判断 是否动画状态
- return this.slideBtn.is(":animated")
- },
- getDragBtnLeft: function () { //判断当前 按钮 离左侧的距离
- return this.slideBtn.css('left');
- },
- ifSlideRight: function () {
- var _this = this;
- if (parseInt(_this.getDragBtnLeft()) == parseInt(_this.calSlideWidth())) {
- return true;
- } else {
- return false;
- }
- },
- setDragBtnSty: function (left) {
- this.slideBtn.css({
- 'left': left
- })
- },
- setDragProgressSty: function (wid) {
- this.slideProEle.css({
- 'width': wid
- })
- },
- cancelMouseMove: function () {
- $(document).off('mousemove');
- },
- cancelTouchmove: function () {
- this.slideBtn.off('touchmove');
- },
- successSty: function () {
- this.slideSucMsgEle.show();
- this.slideBtn.addClass('suc-drag-btn');
- },
- failAnimate: function () {
- this.slideBtn.animate({
- 'left': '-1px'
- }, 200);
- this.slideProEle.animate({
- 'width': 0
- }, 200)
- },
- resetVerify: function () {
- this.slideSucMsgEle.hide();
- this.slideBtn.removeClass('suc-drag-btn');
- this.slideFinishState = false;
- this.slideProEle.css({
- 'width': 0
- });
- this.slideBtn.css({
- 'left': '-1px'
- })
- this._touchmove();
- },
- }
- var inlineCss = '*{margin:0;padding:0;box-sizing:border-box}.verify-wrap{border-radius:6px;width:352px;height:40px;background-color:rgba(255,255,255,.05);border:1px solid #C2C9D1;margin:5px auto;position:relative}.verify-wrap .drag-btn{position:absolute;left:-1px;top:-1px; border-radius: 8px;width:60px;height:40px;background:#ECECEC url() no-repeat center center;background-size:100% 100%;z-index:2;cursor:move;}.verify-wrap .suc-drag-btn{background:#fff url() no-repeat center center;background-size:100% 100%}.verify-wrap .drag-progress{position:absolute;left:0;top:-1px;height:40px;border-top:1px solid #1DB23E;;border-top:1px solid #1DB23E;;width:0;background-color:#1DB23E;;color:#fff;font-size:18px;text-align:center;line-height:40px}.verify-wrap .fix-tips,.verify-msg{border-radius:6px;width:100%;position:absolute;right:0;left:1px;height:100%;color:rgba(0, 0, 0, 0.50);z-index:1;line-height:40px;font-size:15px;text-align:center}.verify-wrap .verify-msg{background-color:#1DB23E;;color:#fff;display:none}';
- var styleObj = $(
- '<style type="text/css">' + inlineCss + '</style>'
- )
- $('head').prepend(styleObj);
- var slideVerify = window.slideVerifyPlug || SlideVerify;
- return slideVerify;
- })));
- })
|