这篇文章将为大家详细讲解有关JS如何实现仿UC浏览器前进后退效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
JS是JavaScript的简称,它是一种直译式的脚本语言,其解释器被称为JavaScript引擎,是浏览器的一部分,主要用于web的开发,可以给网站添加各种各样的动态效果,让网页更加美观。
测试浏览器为谷歌浏览器(谷歌toggle device toolbar)
var startx, starty, endx, endy, moveX, moveY, seatX, seatY; var clickState = false; //获取输入框dom元素 var text = document.forms[“form”]; //设置样式 function setCss(obj) { var cssStr = “z-index:5;width:37px;height:37px;position:absolute;left:” + seatX + ‘px;top:' + seatY + ‘px;'; //将样式添加到div上,显示div obj.style.cssText = cssStr; } //计算位置 function setPosition(obj) { if (obj == ‘left') { seatX = text.offsetLeft - 37; //横坐标 } else { seatX = text.offsetLeft + text.offsetWidth; //横坐标 } seatY = (text.offsetTop + text.offsetHeight) / 2; //纵坐标 } //创建DIV function createDiv(obj) { //首先创建div var descDiv = document.createElement(‘div'); document.body.appendChild(descDiv); //给div设置样式,比如大小、位置 setPosition(obj); setCss(descDiv); descDiv.innerHTML = ”; descDiv.id = obj; descDiv.style.display = ‘block'; addElementImg(descDiv.id); } //添加IMG function addElementImg(obj) { var div = document.getElementById(obj); //添加 img var img = document.createElement(“img”); //设置 img 属性,如 id img.setAttribute(“id”, “newImg”); //设置 img 图片地址 img.src = “/Themes/TheThemeMachine/Images/” + obj + “.png”; div.appendChild(img); } //删除DIV function removeDiv(obj) { var el = document.getElementById(obj); el.parentNode.removeChild(el); } //移动DIV function moveDiv(obj, movex) { if (Math.abs(movex) < 37) { var div = document.getElementById(obj); setPosition(obj); seatX = seatX + movex; setCss(div); } } //根据位移改变DIV的位置 function reductionDiv(obj) { var div = document.getElementById(obj); setPosition(obj); setCss(div); } //计算移动坐标 function calculationMoveCoordinate() { moveX = endx - startx; moveY = Math.abs(endy - starty); if (moveX > 0) moveDiv(“left”, moveX); else moveDiv(“right”, moveX); } //判断是否是PC端 function IsPC() { var userAgentInfo = navigator.userAgent; var Agents = new Array(“Android”, “iPhone”, “SymbianOS”, “Windows Phone”, “iPad”, “iPod”); var flag = true; for (var v = 0; v < Agents.length; v++) { if (userAgentInfo.indexOf(Agents[v]) > 0) { flag = false; break; } } return flag; } //PC端鼠标按下 function click() { clickState = true; startx = event.clientX; starty = event.clientY; } //PC端鼠标移动 function pull() { if (1 == event.which) //判断左键是否按下 { endx = event.clientX; endy = event.clientY; calculationMoveCoordinate(); } } //PC端和移动端位移结束 function stopClick() { if (Math.abs(moveX) > 37 && moveY < 20) { if (moveX < 0) { history.Go(1); } else { history.go(-1); } } else { reductionDiv(“left”); reductionDiv(“right”); } } ////移动端注册事件 document.addEventListener(‘touchmove', function (event) { event.preventDefault(); }, false); //touchstart事件 function touchSatrtFunc(evt) { //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等 var touch = evt.touches[0]; //获取第一个触点 startx = Number(touch.pageX); //页面触点X坐标 starty = Number(touch.pageY); //页面触点Y坐标 } //touchmove事件,这个事件无法获取坐标 function touchMoveFunc(evt) { //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等 var touch = evt.touches[0]; //获取第一个触点 endx = Number(touch.pageX); //页面触点X坐标 endy = Number(touch.pageY); //页面触点Y坐标 calculationMoveCoordinate(); } //touchend事件 function touchEndFunc(evt) { //evt.preventDefault(); //阻止触摸时浏览器的缩放、滚动条滚动等 stopClick(); } //加载 if (IsPC()) { document.onmousedown = click; document.onmousemove = pull; document.onmouseup = stopClick; } else { document.addEventListener(‘touchstart', touchSatrtFunc, false); document.addEventListener(‘touchmove', touchMoveFunc, false); document.addEventListener(‘touchend', touchEndFunc, false); } createDiv(‘left'); createDiv(‘right');
关于“JS如何实现仿UC浏览器前进后退效果”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。