标签:el options var touch ev startPoint 拖拽
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no"> <title>2.4 单指拖拽--拖拽</title> <style> body { height: 2000px; } .backtop { position: fixed; right: 20px; bottom: 20px; width: 45px; height: 45px; line-height: 45px; text-align: center; background-color: rgba(0, 0, 0, 0.6); border-radius: 50%; color: #fff; font-size: 30px; -webkit-tap-highlight-color: transparent; /*transform: translate3d(x, y, 0);*/ } </style> </head> <body> <a href="#" id="backtop" class="backtop">↑</a>
<script> function drag(el, options) { options.x = typeof options.x !== 'undefined' ? options.x : true; options.y = typeof options.y !== 'undefined' ? options.y : false;
if (!options.x && !options.y) return;
var curPoint = { x: 0, y: 0 }; var startPoint = {}; var isTouchMove = false;
el.addEventListener('touchstart', handleStart, false); el.addEventListener('touchmove', handleMove, false); el.addEventListener('touchend', handleEnd, false);
function handleStart(ev) { var touch = ev.changedTouches[0];
startPoint.x = touch.pageX; startPoint.y = touch.pageY; } function handleMove(ev) { ev.preventDefault();
isTouchMove = true;
var touch = ev.changedTouches[0]; var diffPoint = {}; var movePoint = { x: 0, y: 0 };
diffPoint.x = touch.pageX - startPoint.x; diffPoint.y = touch.pageY - startPoint.y;
if (options.x) { movePoint.x = diffPoint.x + curPoint.x; } if (options.y) { movePoint.y = diffPoint.y + curPoint.y; } move(el, movePoint.x, movePoint.y); } function handleEnd(ev) { if (!isTouchMove) return;
var touch = ev.changedTouches[0];
curPoint.x += touch.pageX - startPoint.x; curPoint.y += touch.pageY - startPoint.y;
isTouchMove = false; }
function move(el, x, y) { x = x || 0; y = y || 0;
el.style.transform = 'translate3d(' + x + 'px, ' + y + 'px, 0)'; } } </script> <script> var backtop = document.getElementById('backtop'); drag(backtop, { x: true, y: true }); </script> </body> </html>
标签:el,options,var,touch,ev,startPoint,拖拽
来源: https://www.cnblogs.com/eric-share/p/16334537.html
本站声明:
1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。