js實現(xiàn)拖動滑塊效果
本文實例為大家分享了js如何拖動滑塊的具體代碼,供大家參考,具體內(nèi)容如下
實現(xiàn)拖動滑塊,先分析,滑塊可以拖動應(yīng)該改變滑塊在頁面中的坐標(biāo),那就采用定位拿到元素的 top 和 left 對它們進(jìn)行賦值,接下來就是準(zhǔn)備事件,既然是鼠標(biāo)拖動應(yīng)該具備 mousedown,mousemove,mouseup 三種事件,通過 mousedown 鼠標(biāo)按下事件選中滑塊,mousemove 事件拖動滑塊,在拖動滑塊的時候獲取鼠標(biāo)在可視窗口的坐標(biāo)賦值給滑塊的 top 和 left
具體代碼實現(xiàn)
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <title>Document</title> <style> * { margin: 0; padding: 0; box-sizing: border-box; } div { width: 60px; height: 60px; background-color: coral; border-radius: 20%; position: absolute; border: 6px solid skyblue; left: 0; top: 0; } </style> </head> <body> <div></div> <script> let div = document.querySelector('div') let x, y let fn = function (e) { // console.log('hhhhhhhh') div.style.left = e.clientX - x + 'px' div.style.top = e.clientY - y + 'px' if (e.clientX - x < 30) { div.style.left = 0 } if (e.clientY - y < 30) { div.style.top = 0 } if (e.clientX - x > document.documentElement.clientWidth - div.offsetWidth - 30) { div.style.left = document.documentElement.clientWidth - div.offsetWidth + 'px' } if (e.clientY - y > document.documentElement.clientHeight - div.offsetHeight - 30) { div.style.top = document.documentElement.clientHeight - div.offsetHeight + 'px' } } div.addEventListener('mousedown', function (e) { x = e.offsetX y = e.offsetY document.addEventListener('mousemove', fn) }) div.addEventListener('mouseup', function () { document.removeEventListener('mousemove', fn) }) </script> </body> </html>
運行
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
javascript下利用數(shù)組緩存正則表達(dá)式的實現(xiàn)方法
利用組存大法要提高我們程序的性能,讓我們的正則表達(dá)式的創(chuàng)建于執(zhí)行更有效率。2009-12-12總結(jié)分享10 個超棒的 JavaScript 簡寫技巧
這篇文章主要總結(jié)分享10 個超棒的 JavaScript 簡寫技巧,有合并數(shù)組、克隆數(shù)組、解構(gòu)賦值、模板字面量等技巧,需要的朋友可以參考一下2022-06-06js+css使DIV始終居于屏幕中間 左下 左上 右上 右下的代碼集合
js+css使DIV始終居于屏幕中間 左下 左上 右上 右下的代碼集合,需要的朋友可以參考下。2011-03-03JS實現(xiàn)的RGB網(wǎng)頁顏色在線取色器完整實例
這篇文章主要介紹了JS實現(xiàn)的RGB網(wǎng)頁顏色在線取色器,結(jié)合完整實例形式分析了基于JS運算及鼠標(biāo)事件響應(yīng)來操作頁面元素實現(xiàn)取色器功能的方法,具有一定參考借鑒價值,需要的朋友可以參考下2016-12-12js實現(xiàn)七夕表白彈幕效果 jQuery實現(xiàn)彈幕技術(shù)
這篇文章主要介紹了js實現(xiàn)七夕表白彈幕效果,jQuery實現(xiàn)彈幕技術(shù),文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-08-08JavaScript作用域、閉包、對象與原型鏈概念及用法實例總結(jié)
這篇文章主要介紹了JavaScript作用域、閉包、對象與原型鏈,結(jié)合實例形式總結(jié)分析了javascript中變量與函數(shù)的作用域、閉包、對象、原形鏈相關(guān)概念、用法及注意事項,需要的朋友可以參考下2018-08-08