日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

原生JS封裝拖動驗證滑塊的實現代碼示例

瀏覽:187日期:2024-05-06 08:22:19

前言

星期六閑著沒事,就想著寫寫原生js玩玩,在網上看了幾個效果后決定做這個效果,并且使用了prototype和eventEmitter封裝成了庫。

最終效果

原生JS封裝拖動驗證滑塊的實現代碼示例

分析

看到這個效果我們首先應該想到和拖動有關的api: onmousedown, onmousemove, onmouseup

其次要支持用戶傳入放置這個組件的dom元素和完成的回調事件。

最終如何使用?

我們先來看下使用方式,再來決定我們怎么編寫這個庫

原生JS封裝拖動驗證滑塊的實現代碼示例

具體使用就是這樣的,我們還想用戶能通過import等方式使用,所以我們就要支持esMoudule的導入方式。

編寫庫的整體初始框架

(function () { // =================代碼塊1========================================= var root = (typeof self == ’object’ && self.self == self && self) || (typeof global == ’object’ && global.global == global && global) || this || {}; var util = { extend: function (target) { for (var i = 1, len = arguments.length; i < len; i++) { for (var prop in arguments[i]) { if (arguments[i].hasOwnProperty(prop)) { target[prop] = arguments[i][prop] } } } return target }, isValidListener: function (listener) { if (typeof listener === ’function’) { return true } else if (listener && typeof listener === ’object’) { return util.isValidListener(listener.listener) } else { return false } }, addCSS: function (cssText) { var style = document.createElement(’style’), //創建一個style元素 head = document.head || document.getElementsByTagName(’head’)[0]; //獲取head元素 style.type = ’text/css’; //這里必須顯示設置style元素的type屬性為text/css,否則在ie中不起作用 if (style.styleSheet) { //IE var func = function () { try { //防止IE中stylesheet數量超過限制而發生錯誤 style.styleSheet.cssText = cssText; } catch (e) { } } //如果當前styleSheet還不能用,則放到異步中則行 if (style.styleSheet.disabled) { setTimeout(func, 10); } else { func(); } } else { //w3c //w3c瀏覽器中只要創建文本節點插入到style元素中就行了 var textNode = document.createTextNode(cssText); style.appendChild(textNode); } head.appendChild(style); //把創建的style元素插入到head中 }, indexOf: function (array, item) { if (array.indexOf) { return array.indexOf(item); } else { var result = -1; for (var i = 0, len = array.length; i < len; i++) { if (array[i] === item) { result = i; break; } } return result; } } } function EventEmitter() { this._events = {} } EventEmitter.prototype.on = function (eventName, listener) { if (!eventName || !listener) return; if (!util.isValidListener(listener)) { throw new TypeError(’listener must be a function’); } var events = this._events; var listeners = events[eventName] = events[eventName] || []; var listenerIsWrapped = typeof listener === ’object’; // 不重復添加事件 if (util.indexOf(listeners, listener) === -1) { listeners.push(listenerIsWrapped ? listener : { listener: listener, once: false }); } return this; }; EventEmitter.prototype.once = function (eventName, listener) { return this.on(eventName, { listener: listener, once: true }) }; EventEmitter.prototype.off = function (eventName, listener) { var listeners = this._events[eventName]; if (!listeners) return; var index; for (var i = 0, len = listeners.length; i < len; i++) { if (listeners[i] && listeners[i].listener === listener) { index = i; break; } } if (typeof index !== ’undefined’) { listeners.splice(index, 1, null) } return this; }; EventEmitter.prototype.emit = function (eventName, args) { var listeners = this._events[eventName]; if (!listeners) return; for (var i = 0; i < listeners.length; i++) { var listener = listeners[i]; if (listener) { listener.listener.apply(this, args || []); if (listener.once) { this.off(eventName, listener.listener) } } } return this; }; // =================代碼塊2========================================= function SliderTools(options) { this.options = util.extend({}, this.constructor.defaultOptions, options) this.init(); this.bindEvents(); this.diffX = 0; this.flag = false;//是否拖動到最右側 } SliderTools.defaultOptions = { el: document.body //默認放到body里 }; var proto = SliderTools.prototype = new EventEmitter();//SliderTools繼承emitter proto.constructor = SliderTools;//修正構造器 proto.init = function () { this.createSlider();//創建插件所需要的dom元素 this.getElements();//獲取創建好的元素 } // =================代碼塊3========================================= if (typeof exports != ’undefined’ && !exports.nodeType) { if (typeof module != ’undefined’ && !module.nodeType && module.exports) { exports = module.exports = SliderTools; } exports.SliderTools = SliderTools; } else { root.SliderTools = SliderTools; }}());

代碼塊1是在判斷是在瀏覽器環境還是nodeJS環境,方便代碼三后期使用, 代碼塊2聲明了一個對象 SliderTools ,將用戶傳進來的 option 和默認的 defaultOption 進行合并

編寫核心函數1(創建dom和css)

proto.createSlider = function () { this.options.el.innerHTML = ’<div id='slider'><div class='drag_bg'></div><div onselectstart='return false;' unselectable='on'>拖動滑塊驗證</div><div class='handler handler_bg'></div></div>’;//像指定元素中放置插件的dom元素 util.addCSS(’ul,li {list-style: none;} a {text-decoration: none;} .wrap {width: 300px;height: 350px;text-align: center;margin: 150px auto;}.inner {padding: 15px;} .clearfix {overflow: hidden;_zoom: 1;} .none {display: none;} #slider {position:relative;background-color: #e8e8e8;width: 300px;height: 34px;line-height: 34px;text-align: center;} #slider .handler {position: absolute;top: 0px;left: 0px;width: 40px;height: 32px;border: 1px solid #ccc;cursor: move;} .handler_bg {background: #fff url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NTEyNTVEMURGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NTEyNTVEMUNGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo2MTc5NzNmZS02OTQxLTQyOTYtYTIwNi02NDI2YTNkOWU5YmUiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+YiRG4AAAALFJREFUeNpi/P//PwMlgImBQkA9A+bOnfsIiBOxKcInh+yCaCDuByoswaIOpxwjciACFegBqZ1AvBSIS5OTk/8TkmNEjwWgQiUgtQuIjwAxUF3yX3xyGIEIFLwHpKyAWB+I1xGSwxULIGf9A7mQkBwTlhBXAFLHgPgqEAcTkmNCU6AL9d8WII4HOvk3ITkWJAXWUMlOoGQHmsE45ViQ2KuBuASoYC4Wf+OUYxz6mQkgwAAN9mIrUReCXgAAAABJRU5ErkJggg==') no-repeat center;} .handler_ok_bg {background: #fff url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NDlBRDI3NjVGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NDlBRDI3NjRGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDphNWEzMWNhMC1hYmViLTQxNWEtYTEwZS04Y2U5NzRlN2Q4YTEiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+k+sHwwAAASZJREFUeNpi/P//PwMyKD8uZw+kUoDYEYgloMIvgHg/EM/ptHx0EFk9I8wAoEZ+IDUPiIMY8IN1QJwENOgj3ACo5gNAbMBAHLgAxA4gQ5igAnNJ0MwAVTsX7IKyY7L2UNuJAf+AmAmJ78AEDTBiwGYg5gbifCSxFCZoaBMCy4A4GOjnH0D6DpK4IxNSVIHAfSDOAeLraJrjgJp/AwPbHMhejiQnwYRmUzNQ4VQgDQqXK0ia/0I17wJiPmQNTNBEAgMlQIWiQA2vgWw7QppBekGxsAjIiEUSBNnsBDWEAY9mEFgMMgBk00E0iZtA7AHEctDQ58MRuA6wlLgGFMoMpIG1QFeGwAIxGZo8GUhIysmwQGSAZgwHaEZhICIzOaBkJkqyM0CAAQDGx279Jf50AAAAAABJRU5ErkJggg==') no-repeat center;}#slider .drag_bg {background-color: #7ac23c; height: 34px;width: 0px;} #slider .drag_text {position: absolute; top: 0px;width: 300px;-moz-user-select: none;-webkit-user-select: none;user-select: none;-o-user-select: none;-ms-user-select: none; }.unselect {-moz-user-select: none;-webkit-user-select: none; -ms-user-select: none;}.slide_ok {color: #fff;}’)//像頁面里add新的樣式}proto.getElements = function () { this.slider = document.querySelector(’#slider’); this.drag_bg = document.querySelector(’.drag_bg’); this.handler = document.querySelector(’.handler’);}

編寫核心函數2(綁定事件)

proto.bindEvents = function () { var self = this; self.handler.onmousedown = function (e) { self.diffX = e.clientX - self.handler.offsetLeft; util.setClassName(self.slider, ’unselect’); //禁止選擇樣式 document.onmousemove = function (e) { let deltaX = e.clientX - self.diffX; if (deltaX >= self.slider.offsetWidth - self.handler.offsetWidth) { //拖動到了最右側 deltaX = self.slider.offsetWidth - self.handler.offsetWidth; self.flag = true; } else if (deltaX <= 0) { deltaX = 0; self.flag = false; } else { self.flag = false; } util.setInlineStyle([self.handler], ’left’, deltaX + ’px’); util.setInlineStyle([self.drag_bg], ’width’, deltaX + ’px’); } document.onmouseup = function (e) { util.setClassName(self.slider, ’’) if (self.flag) { util.setClassName(self.slider, ’slide_ok’) //拖動完成后的樣式 util.addClass(self.handler, ’handler_ok_bg’)////拖動完成后的樣式 self.handler.onmousedown = null //防止拖動完成后再次拖動 self.emit(’complete’)//emit通知使用者的回調事件 } else { util.setInlineStyle([self.handler], ’left’, 0 + ’px’); util.setInlineStyle([self.drag_bg], ’width’, 0 + ’px’); } document.onmousemove = null; document.onmouseup = null; } }}

添加工具方法(核心函數2中用到的)

var util = { // ...初始框架里的那部分 setClassName(selector, className) { selector.className = className; }, addClass(selector, className) { selector.classList.add(className); }, setInlineStyle(selector, attr, content) { let length = selector.length; for (let i = 0; i < length; i++) { selector[i].style[attr] = content; } },}

最終完整可運行代碼

(function () { var root = (typeof self == ’object’ && self.self == self && self) || (typeof global == ’object’ && global.global == global && global) || this || {}; var util = { extend: function (target) { for (var i = 1, len = arguments.length; i < len; i++) { for (var prop in arguments[i]) { if (arguments[i].hasOwnProperty(prop)) { target[prop] = arguments[i][prop] } } } return target }, setClassName(selector, className) { selector.className = className; }, addClass(selector, className) { selector.classList.add(className); }, setInlineStyle(selector, attr, content) { let length = selector.length; for (let i = 0; i < length; i++) { selector[i].style[attr] = content; } }, isValidListener: function (listener) { if (typeof listener === ’function’) { return true } else if (listener && typeof listener === ’object’) { return util.isValidListener(listener.listener) } else { return false } }, addCSS: function (cssText) { var style = document.createElement(’style’), //創建一個style元素 head = document.head || document.getElementsByTagName(’head’)[0]; //獲取head元素 style.type = ’text/css’; //這里必須顯示設置style元素的type屬性為text/css,否則在ie中不起作用 if (style.styleSheet) { //IE var func = function () { try { //防止IE中stylesheet數量超過限制而發生錯誤 style.styleSheet.cssText = cssText; } catch (e) { } } //如果當前styleSheet還不能用,則放到異步中則行 if (style.styleSheet.disabled) { setTimeout(func, 10); } else { func(); } } else { //w3c //w3c瀏覽器中只要創建文本節點插入到style元素中就行了 var textNode = document.createTextNode(cssText); style.appendChild(textNode); } head.appendChild(style); //把創建的style元素插入到head中 }, indexOf: function (array, item) { if (array.indexOf) { return array.indexOf(item); } else { var result = -1; for (var i = 0, len = array.length; i < len; i++) { if (array[i] === item) { result = i; break; } } return result; } } } function EventEmitter() { this._events = {} } EventEmitter.prototype.on = function (eventName, listener) { if (!eventName || !listener) return; if (!util.isValidListener(listener)) { throw new TypeError(’listener must be a function’); } var events = this._events; var listeners = events[eventName] = events[eventName] || []; var listenerIsWrapped = typeof listener === ’object’; // 不重復添加事件 if (util.indexOf(listeners, listener) === -1) { listeners.push(listenerIsWrapped ? listener : { listener: listener, once: false }); } return this; }; EventEmitter.prototype.once = function (eventName, listener) { return this.on(eventName, { listener: listener, once: true }) }; EventEmitter.prototype.off = function (eventName, listener) { var listeners = this._events[eventName]; if (!listeners) return; var index; for (var i = 0, len = listeners.length; i < len; i++) { if (listeners[i] && listeners[i].listener === listener) { index = i; break; } } if (typeof index !== ’undefined’) { listeners.splice(index, 1, null) } return this; }; EventEmitter.prototype.emit = function (eventName, args) { var listeners = this._events[eventName]; if (!listeners) return; for (var i = 0; i < listeners.length; i++) { var listener = listeners[i]; if (listener) { listener.listener.apply(this, args || []); if (listener.once) { this.off(eventName, listener.listener) } } } return this; }; function SliderTools(options) { this.options = util.extend({}, this.constructor.defaultOptions, options) this.init(); this.bindEvents(); this.diffX = 0; this.flag = false; } SliderTools.VERSION = ’1.0.0’; SliderTools.defaultOptions = { el: document.body }; var proto = SliderTools.prototype = new EventEmitter(); proto.constructor = SliderTools; proto.init = function () { this.createSlider(); this.getElements(); } proto.createSlider = function () { this.options.el.innerHTML = ’<div id='slider'><div class='drag_bg'></div><div onselectstart='return false;' unselectable='on'>拖動滑塊驗證</div><div class='handler handler_bg'></div></div>’; util.addCSS(’ul, li { list-style: none; } a { text-decoration: none; } .wrap { width: 300px; height: 350px; text-align: center; margin: 150px auto; } .inner { padding: 15px; } .clearfix { overflow: hidden; _zoom: 1; } .none { display: none; } #slider { position: relative; background-color: #e8e8e8; width: 300px; height: 34px; line-height: 34px; text-align: center; } #slider .handler { position: absolute; top: 0px; left: 0px; width: 40px; height: 32px; border: 1px solid #ccc; cursor: move;} .handler_bg { background: #fff url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NTEyNTVEMURGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NTEyNTVEMUNGMkVFMTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDo2MTc5NzNmZS02OTQxLTQyOTYtYTIwNi02NDI2YTNkOWU5YmUiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+YiRG4AAAALFJREFUeNpi/P//PwMlgImBQkA9A+bOnfsIiBOxKcInh+yCaCDuByoswaIOpxwjciACFegBqZ1AvBSIS5OTk/8TkmNEjwWgQiUgtQuIjwAxUF3yX3xyGIEIFLwHpKyAWB+I1xGSwxULIGf9A7mQkBwTlhBXAFLHgPgqEAcTkmNCU6AL9d8WII4HOvk3ITkWJAXWUMlOoGQHmsE45ViQ2KuBuASoYC4Wf+OUYxz6mQkgwAAN9mIrUReCXgAAAABJRU5ErkJggg==') no-repeat center; } .handler_ok_bg { background: #fff url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQCAYAAAAf8/9hAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAA3hpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuNS1jMDIxIDc5LjE1NTc3MiwgMjAxNC8wMS8xMy0xOTo0NDowMCAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wTU09Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9tbS8iIHhtbG5zOnN0UmVmPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvc1R5cGUvUmVzb3VyY2VSZWYjIiB4bWxuczp4bXA9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC8iIHhtcE1NOk9yaWdpbmFsRG9jdW1lbnRJRD0ieG1wLmRpZDo0ZDhlNWY5My05NmI0LTRlNWQtOGFjYi03ZTY4OGYyMTU2ZTYiIHhtcE1NOkRvY3VtZW50SUQ9InhtcC5kaWQ6NDlBRDI3NjVGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcE1NOkluc3RhbmNlSUQ9InhtcC5paWQ6NDlBRDI3NjRGMkQ2MTFFNEI5NDBCMjQ2M0ExMDQ1OUYiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENDIDIwMTQgKE1hY2ludG9zaCkiPiA8eG1wTU06RGVyaXZlZEZyb20gc3RSZWY6aW5zdGFuY2VJRD0ieG1wLmlpZDphNWEzMWNhMC1hYmViLTQxNWEtYTEwZS04Y2U5NzRlN2Q4YTEiIHN0UmVmOmRvY3VtZW50SUQ9InhtcC5kaWQ6NGQ4ZTVmOTMtOTZiNC00ZTVkLThhY2ItN2U2ODhmMjE1NmU2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+k+sHwwAAASZJREFUeNpi/P//PwMyKD8uZw+kUoDYEYgloMIvgHg/EM/ptHx0EFk9I8wAoEZ+IDUPiIMY8IN1QJwENOgj3ACo5gNAbMBAHLgAxA4gQ5igAnNJ0MwAVTsX7IKyY7L2UNuJAf+AmAmJ78AEDTBiwGYg5gbifCSxFCZoaBMCy4A4GOjnH0D6DpK4IxNSVIHAfSDOAeLraJrjgJp/AwPbHMhejiQnwYRmUzNQ4VQgDQqXK0ia/0I17wJiPmQNTNBEAgMlQIWiQA2vgWw7QppBekGxsAjIiEUSBNnsBDWEAY9mEFgMMgBk00E0iZtA7AHEctDQ58MRuA6wlLgGFMoMpIG1QFeGwAIxGZo8GUhIysmwQGSAZgwHaEZhICIzOaBkJkqyM0CAAQDGx279Jf50AAAAAABJRU5ErkJggg==') no-repeat center; } #slider .drag_bg { background-color: #7ac23c; height: 34px; width: 0px; } #slider .drag_text { position: absolute; top: 0px; width: 300px; -moz-user-select: none; -webkit-user-select: none; user-select: none; -o-user-select: none; -ms-user-select: none; } .unselect { -moz-user-select: none; -webkit-user-select: none; -ms-user-select: none; } .slide_ok { color: #fff; }’) } proto.getElements = function () { this.slider = document.querySelector(’#slider’); this.drag_bg = document.querySelector(’.drag_bg’); this.handler = document.querySelector(’.handler’); } proto.bindEvents = function () { var self = this; self.handler.onmousedown = function (e) { self.diffX = e.clientX - self.handler.offsetLeft; util.setClassName(self.slider, ’unselect’); document.onmousemove = function (e) { let deltaX = e.clientX - self.diffX; if (deltaX >= self.slider.offsetWidth - self.handler.offsetWidth) { deltaX = self.slider.offsetWidth - self.handler.offsetWidth; self.flag = true; } else if (deltaX <= 0) { deltaX = 0; self.flag = false; } else { self.flag = false; } util.setInlineStyle([self.handler], ’left’, deltaX + ’px’); util.setInlineStyle([self.drag_bg], ’width’, deltaX + ’px’); } document.onmouseup = function (e) { util.setClassName(self.slider, ’’) if (self.flag) { util.setClassName(self.slider, ’slide_ok’) util.addClass(self.handler, ’handler_ok_bg’) self.handler.onmousedown = null self.emit(’complete’) } else { util.setInlineStyle([self.handler], ’left’, 0 + ’px’); util.setInlineStyle([self.drag_bg], ’width’, 0 + ’px’); } document.onmousemove = null; document.onmouseup = null; } } } if (typeof exports != ’undefined’ && !exports.nodeType) { if (typeof module != ’undefined’ && !module.nodeType && module.exports) { exports = module.exports = SliderTools; } exports.SliderTools = SliderTools; } else { root.SliderTools = SliderTools; }}());let slider = new SliderTools();slider.on(’complete’,() => { alert(’驗證完成’);})

結語

參考資料

到此這篇關于原生JS封裝拖動驗證滑塊的實現代碼示例的文章就介紹到這了,更多相關JS 拖動驗證滑塊內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲a一区二区三区| 极品日韩av| 亚洲精品字幕| 综合激情网...| 亚洲久久视频| 免费观看在线色综合| 蜜桃传媒麻豆第一区在线观看| 欧美日韩国产欧| 亚洲少妇在线| 一区二区日韩免费看| 精品日韩毛片| 欧美一级专区| 亚洲毛片在线| 青青草精品视频| 麻豆精品在线播放| 精品中文在线| 四虎4545www国产精品 | 精品国产乱码久久久| 国产一区福利| 欧美日一区二区| 蜜桃一区二区三区| 国产+成+人+亚洲欧洲在线| 亚洲爱爱视频| 巨乳诱惑日韩免费av| 日韩高清不卡一区二区| 国产福利资源一区| 天堂日韩电影| 一二三区精品| 久久亚洲精精品中文字幕| 在线亚洲人成| 日韩专区一卡二卡| 国产欧美日韩一级| 精品免费av在线| 在线精品一区| 国产一区二区三区不卡视频网站| 在线亚洲人成| 亚洲伊人影院| 精品视频在线一区二区在线| 久久亚洲在线| 日韩精品免费一区二区夜夜嗨 | 午夜亚洲一区| 国产精品一区二区av交换 | 不卡在线一区二区| 亚洲精品高潮| 国产精品久久久久久久久久白浆 | 日本不卡一区二区| 成人在线观看免费视频| 欧美亚洲国产激情| 日本aⅴ精品一区二区三区| 日韩成人精品一区二区| 在线视频日韩| 久久中文字幕一区二区三区| 影视先锋久久| 国产毛片精品久久| 欧美日韩国产亚洲一区| 久久国产精品美女| 99久久久久国产精品| 91亚洲精品在看在线观看高清| 久久久久久夜| 日韩手机在线| 久久久777| 国产精品综合色区在线观看| 国内精品福利| 久久伊人久久| 中文字幕一区二区三区日韩精品 | 久久激情中文| 91国内精品| 99久久亚洲精品| 久久精品xxxxx| 亚洲少妇在线| 天堂av在线| 国产日韩欧美一区在线| 不卡av一区二区| 精品国产午夜肉伦伦影院| 老色鬼久久亚洲一区二区| 国产v日韩v欧美v| 亚洲毛片在线免费| 99久久夜色精品国产亚洲1000部| 国产亚洲第一伦理第一区| 日韩视频不卡| 中文字幕在线高清| 欧美日韩一区自拍| 首页欧美精品中文字幕| 亚洲不卡av不卡一区二区| 国产精品22p| 亚洲天堂av资源在线观看| 久久在线免费| 亚洲一区资源| 美腿丝袜亚洲一区| 日韩精彩视频在线观看| 欧美日韩四区| 国产99精品| 亚洲精品国产嫩草在线观看| 红杏一区二区三区| 国产欧美日韩免费观看| 天海翼精品一区二区三区| 久久国产精品成人免费观看的软件| 国产精品一线| 日韩不卡在线观看日韩不卡视频| 亚洲一区二区成人| 91久久国产| 日韩不卡视频在线观看| 国产成人免费精品| 久久只有精品| 国产精品日韩精品中文字幕| 日本中文字幕不卡| 亚洲一区二区三区无吗| 先锋影音国产一区| 国产亚洲在线观看| 99视频在线精品国自产拍免费观看| 日本免费久久| 成人亚洲一区| 国产精品久久久久蜜臀| 久久亚洲黄色| 国际精品欧美精品| 久久精品人人| 精品网站999| 成人午夜网址| 日本综合字幕| 久久精品免费一区二区三区| 久久久久久免费视频| 亚洲午夜视频| 99re国产精品| 蜜桃91丨九色丨蝌蚪91桃色| 日韩中文字幕av电影| 午夜亚洲福利在线老司机| 中文精品在线| 一区二区国产精品| 日本aⅴ免费视频一区二区三区| 欧美久久精品| 国产一区二区三区四区大秀| 高清一区二区三区| 精精国产xxxx视频在线播放| 欧美精品资源| 亚洲高清影视| 亚洲欧美在线专区| 国产日韩欧美中文在线| 精品一区二区三区中文字幕在线| 久久精品国产一区二区| 精品国产一区二| 人人香蕉久久| 国产主播一区| 免费在线看一区| 91大神在线观看线路一区| 久久精选视频| av中文资源在线资源免费观看| 蜜桃久久精品一区二区| 亚洲免费在线| 日本伊人午夜精品| 欧美另类综合| 男人的天堂久久精品| 日韩在线成人| 国产精品一级在线观看| 精品亚洲成人| 在线一区视频观看| 久久国产成人| 亚洲三级国产| 国产精品久久久久av蜜臀| 国内精品伊人| 亚洲激精日韩激精欧美精品| 日韩区欧美区| 成人在线免费观看91| 欧美另类综合| 久久国产麻豆精品| 伊人网在线播放| 亚洲一区日韩在线| 欧美天堂一区| 久久国产免费| 日韩精选在线| 91日韩在线| 热久久免费视频| 久久丁香四色| 91高清一区| 日韩va亚洲va欧美va久久| 欧美a在线观看| 激情综合自拍| 日本aⅴ亚洲精品中文乱码 | 91久久久久| 日韩不卡一区二区三区| 神马午夜在线视频| 免费黄网站欧美| 精品淫伦v久久水蜜桃| 亚洲少妇诱惑| 久久av资源| 午夜一级久久| 国产一区二区三区日韩精品| 国产亚洲精品久久久久婷婷瑜伽| 欧美极品一区二区三区| 欧美日韩免费观看一区=区三区| 国产精品嫩模av在线| 欧美日韩国产一区精品一区| 国产精品白浆| 日韩视频一区二区三区在线播放免费观看| 欧美日韩一区二区三区四区在线观看| 亚洲成人精品| 国产极品一区| 视频一区在线视频| 日韩久久精品网| 日韩欧美在线精品| 久久久精品日韩|