中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

JS如何實現仿UC瀏覽器前進后退效果

發布時間:2021-04-23 11:06:56 來源:億速云 閱讀:186 作者:小新 欄目:web開發

這篇文章將為大家詳細講解有關JS如何實現仿UC瀏覽器前進后退效果,小編覺得挺實用的,因此分享給大家做個參考,希望大家閱讀完這篇文章后可以有所收獲。

JS是什么

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瀏覽器前進后退效果”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,使各位可以學到更多知識,如果覺得文章不錯,請把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

额尔古纳市| 双峰县| 井陉县| 英德市| 府谷县| 玉龙| 珲春市| 定陶县| 防城港市| 德清县| 呼和浩特市| 张家川| 吉隆县| 多伦县| 西吉县| 达拉特旗| 甘肃省| 开原市| 保靖县| 大荔县| 新平| 沙雅县| 和硕县| 朝阳市| 建德市| 吉安市| 乳山市| 周宁县| 溧阳市| 西乌珠穆沁旗| 威远县| 长寿区| 叙永县| 定日县| 平远县| 泗水县| 甘德县| 华坪县| 肇东市| 泽库县| 固阳县|