欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JS實現(xiàn)仿UC瀏覽器前進后退效果的實例代碼

 更新時間:2017年07月17日 14:08:50   作者:心之所向  
這篇文章主要介紹了JS實現(xiàn)仿UC瀏覽器前進后退效果的實例代碼,實現(xiàn)此功能前需要先測試下瀏覽器,具體實例代碼,大家參考下本文

測試瀏覽器為谷歌瀏覽器(谷歌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; //縱坐標 
} 
//創(chuàng)建DIV 
function createDiv(obj) { 
//首先創(chuàng)建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); 
} 
} 
//根據(jù)位移改變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(“l(fā)eft”, 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端和移動端位移結(jié)束 
function stopClick() { 
if (Math.abs(moveX) > 37 && moveY < 20) { 
if (moveX < 0) { 
history.Go(1); 
} else { 
history.go(-1); 
} 
} else { 
reductionDiv(“l(fā)eft”); 
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實現(xiàn)仿UC瀏覽器前進后退效果的實例代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • js使用navigator.userAgent判斷當前瀏覽器所處的環(huán)境

    js使用navigator.userAgent判斷當前瀏覽器所處的環(huán)境

    本文主要介紹了js使用navigator.userAgent判斷當前瀏覽器所處的環(huán)境,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-04-04
  • js鍵盤事件的keyCode

    js鍵盤事件的keyCode

    本節(jié)主要介紹了js鍵盤事件的keyCode,在你按下鍵時會彈出它的鍵碼,需要的朋友可以參考下
    2014-07-07
  • SOSO地圖API使用(一)在地圖上畫圓實現(xiàn)思路與代碼

    SOSO地圖API使用(一)在地圖上畫圓實現(xiàn)思路與代碼

    最近在做SOSO地圖相關(guān)開發(fā),遇到相關(guān)畫圓知識,特此簡單記錄下來,接下來講解如何在在地圖上畫圓,感興趣的朋友可以了解下
    2013-01-01
  • JavaScript 異步調(diào)用框架 (Part 6 - 實例 & 模式)

    JavaScript 異步調(diào)用框架 (Part 6 - 實例 & 模式)

    我們用了5篇文章來討論如何編寫一個JavaScript異步調(diào)用框架(問題 & 場景、用例設計、代碼實現(xiàn)、鏈式調(diào)用、鏈式實現(xiàn)),現(xiàn)在是時候讓我們看一下在各種常見開發(fā)情景中如何使用它了。
    2009-08-08
  • bootstrap fileinput 插件使用項目總結(jié)(經(jīng)驗)

    bootstrap fileinput 插件使用項目總結(jié)(經(jīng)驗)

    這篇文章主要介紹了bootstrap fileinput 插件使用項目總結(jié),是小編日常碰到的問題及解決方法,需要的朋友可以參考下
    2017-02-02
  • 簡單的兩種Extjs formpanel加載數(shù)據(jù)的方式

    簡單的兩種Extjs formpanel加載數(shù)據(jù)的方式

    這篇文章介紹了兩種Extjs formpanel加載數(shù)據(jù)的方式,有需要的朋友可以參考一下
    2013-11-11
  • layui中的tab控件點擊切換觸發(fā)事件

    layui中的tab控件點擊切換觸發(fā)事件

    這篇文章主要介紹了layui中的tab控件點擊切換觸發(fā)事件,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-06-06
  • Javascript控制div屬性動態(tài)變化實例分析

    Javascript控制div屬性動態(tài)變化實例分析

    這篇文章主要介紹了Javascript控制div屬性動態(tài)變化,以實例形式較為詳細的分析了JavaScript響應鼠標事件動態(tài)操作頁面元素屬性的技巧,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-10-10
  • 向大師們學習Javascript(視頻與PPT)

    向大師們學習Javascript(視頻與PPT)

    在開始之前,先與大家一起認識下這篇文章的主角,世界級的javascript大牛們:Douglas Crockford、John Resig、Peter-Paul Koch、Nicolas C. Zakas??疵忠苍S挺陌生,但是如果你對javascript還算熟悉,一定不會對他們的作品陌生。
    2009-12-12
  • 微信小程序分包操作實戰(zhàn)指南

    微信小程序分包操作實戰(zhàn)指南

    分包指的是把一個完整的小程序項目,按照需求劃分為不同的子包, 在構(gòu)建時打包成不同的分包,用戶在使用時按需進行加載,下面這篇文章主要給大家介紹了關(guān)于微信小程序分包操作的相關(guān)資料,需要的朋友可以參考下
    2022-10-10

最新評論