jQuery手機(jī)瀏覽器中拖拽動(dòng)作的艱難性分析
本文實(shí)例分析了jQuery手機(jī)瀏覽器中拖拽動(dòng)作的艱難性。分享給大家供大家參考。具體如下:
本想在手機(jī)網(wǎng)頁(yè)中實(shí)現(xiàn)一個(gè)如iphone可以隨意拖動(dòng)的控制按鈕的,但是最后發(fā)現(xiàn)竹籃打水一場(chǎng)空,
雖然拖拽動(dòng)作在手機(jī)瀏覽器中司空見(jiàn)慣,但是在手機(jī)瀏覽器中,要想實(shí)現(xiàn)可以被拖拽的組件,卻是一件不可能的事情。
先來(lái)看看在PC網(wǎng)頁(yè)中,拖拽動(dòng)作是怎么做的,
首先,我們有一個(gè)按鈕,點(diǎn)擊有動(dòng)作,一直按著不放,可以隨意拖動(dòng),就像iphone可以隨意拖動(dòng)的控制按鈕一樣,
如上圖的灰色圖層,寫(xiě)出來(lái)也不甚容易,
首先,要把灰色圖層的position屬性變?yōu)閍bosulte,之后在jquery腳本要實(shí)現(xiàn)的工作要點(diǎn),是區(qū)分click與mousedown+mouseup這一對(duì)動(dòng)作,因?yàn)閏lick本來(lái)就等于mousedown+mouseup,但是還好,mousedown一段時(shí)間時(shí)候,馬上unbind清空?qǐng)D層對(duì)cilck動(dòng)作的綁定,告訴系統(tǒng),mousedown之后的動(dòng)作與click無(wú)關(guān),見(jiàn)如下現(xiàn)實(shí)代碼:
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>jqdrag</title>
<meta name="viewport" content="width=device-width,initial-scale=1.0,user-scalable=no">
<script type="text/javascript" src="js/jquery-1.11.1.js"></script>
</head>
<body>
<div id="mydiv" style="width:100px; height:100px; background:#999; position:absolute;">out</div>
</body>
</html>
<script type="text/javascript">
$(document).ready(function() {
var timeout ;
$("#mydiv").mousedown(function(e) {
/*相當(dāng)于mousedown之后立即進(jìn)行判斷,到底用戶有沒(méi)有按下超過(guò)1秒,有則判定為長(zhǎng)按*/
$("#mydiv").click(function() {
$("#mydiv").text("被點(diǎn)擊");
});
timeout = setTimeout(function() {
$("#mydiv").text("長(zhǎng)按");
/*以下的語(yǔ)句之后,用戶鼠標(biāo)左鍵放起,則不會(huì)判定為click動(dòng)作*/
$("#mydiv").unbind("click");
$("#mydiv").mousemove(function (e) {
/*這里是為了鼠標(biāo)拖拽圖層移動(dòng)的時(shí)候,鼠標(biāo)剛好在圖層中間*/
document .getElementById("mydiv").style.left = e.pageX-50 + "px";
document .getElementById("mydiv").style.top = e.pageY-50 + "px";
});
}, 1000)
});
$("#mydiv").mouseup(function() {
clearTimeout(timeout);
/*這里必須清空mousemove動(dòng)作,否則圖層會(huì)永遠(yuǎn)綁定mousemove動(dòng)作,隨著鼠標(biāo)移動(dòng)而移動(dòng)*/
$("#mydiv").unbind("mousemove");
$("#mydiv").text("out");
});
$("#mydiv").mouseout(function() {
clearTimeout(timeout);
$("#mydiv").unbind("mousemove");
$("#mydiv").text("out");
});
});
</script>
之所以還要編寫(xiě)mouseout事件,與之前的【jQuery實(shí)現(xiàn)長(zhǎng)按按鈕觸發(fā)事件的方法】一文一樣,防止瀏覽器中,涂黑躲過(guò)mouseup判定的bug。
以上看起來(lái)非常地完美,因?yàn)樵赑C各大瀏覽器測(cè)試通過(guò),還完美兼容IE8,實(shí)在是美如畫(huà),
但是,一到手機(jī)中就問(wèn)題大了,
僅僅在google瀏覽器中手機(jī)調(diào)試模式中,還沒(méi)有到真機(jī)上了,就無(wú)法使用了!
jquery的點(diǎn)擊事件在手機(jī)瀏覽器中是沒(méi)有任何問(wèn)題的,但是,長(zhǎng)按事件卻與手機(jī)上系統(tǒng)自帶的右鍵功能發(fā)生了沖突,即使換成jquery mobile中的.on("taphold",function (){});事件或者是在上面的mousedown中加入e.preventDefault();IE則用window.event.preventDefault();I禁用手機(jī)瀏覽器的自帶的菜單,也只能使長(zhǎng)按的功能留存,拖拽是不用想了,因?yàn)橥献ё钪饕暮瘮?shù)就是mousemove動(dòng)作,手機(jī)瀏覽器上根本就不支持mousemove()動(dòng)作。
于是,有人提出抗議了,可以用jquery ui中的.draggable()與jquerymobile中的swipe事件,實(shí)在html5中的拖拽事件??!
然而,上述所有的解決方案都是徒勞無(wú)功,
對(duì)于jquery ui中的.draggable(),jquerymobile中的swipe事件,html5中的拖拽事件可以用瀏覽器的手機(jī)調(diào)試模式,發(fā)現(xiàn)根本就沒(méi)法拖。
希望本文所述對(duì)大家的jquery程序設(shè)計(jì)有所幫助。
- JS 動(dòng)態(tài)判斷PC和手機(jī)瀏覽器實(shí)現(xiàn)代碼
- 使用JavaScript判斷手機(jī)瀏覽器是橫屏還是豎屏問(wèn)題
- php判斷手機(jī)瀏覽還是web瀏覽,并執(zhí)行相應(yīng)的動(dòng)作簡(jiǎn)單實(shí)例
- 如何解決手機(jī)瀏覽器頁(yè)面點(diǎn)擊不跳轉(zhuǎn)瀏覽器雙擊放大網(wǎng)頁(yè)
- 微信或手機(jī)瀏覽器在線顯示office文件(已測(cè)試ios、android)
- js判斷手機(jī)瀏覽器操作系統(tǒng)和微信瀏覽器的方法
- 兩款JS腳本判斷手機(jī)瀏覽器類型跳轉(zhuǎn)WAP手機(jī)網(wǎng)站
- JS腳本根據(jù)手機(jī)瀏覽器類型跳轉(zhuǎn)WAP手機(jī)網(wǎng)站(兩種方式)
- 通過(guò)JS自動(dòng)隱藏手機(jī)瀏覽器的地址欄實(shí)現(xiàn)原理與代碼
- 手機(jī)瀏覽器 后退按鈕強(qiáng)制刷新頁(yè)面方法總結(jié)
相關(guān)文章
AspNet中使用JQuery上傳插件Uploadify詳解
Uploadify是JQuery的一個(gè)上傳插件,實(shí)現(xiàn)的效果非常不錯(cuò),帶進(jìn)度顯示。不過(guò)官方提供的實(shí)例時(shí)php版本的,本文將詳細(xì)介紹Uploadify在Aspnet中的使用2015-05-05Jquery中$.post和$.ajax的用法小結(jié)
本節(jié)重點(diǎn)講的是jquery中調(diào)用ajax的4種方法中最常用的:$.post、和$ajax。如果讀者沒(méi)有javascript和jquery的知識(shí),或者沒(méi)有ajax的概念,那么請(qǐng)先去問(wèn)問(wèn)度娘,再來(lái)讀本文。2015-04-04jQuery根據(jù)ID獲取input、checkbox、radio、select的示例
獲取input、checkbox、radio、select的方法有很多,下面本例為大家介紹下根據(jù)ID來(lái)獲取2014-08-08jQuery+canvas實(shí)現(xiàn)的球體平拋及顏色動(dòng)態(tài)變換效果
這篇文章主要介紹了jQuery+canvas實(shí)現(xiàn)的球體平拋及顏色動(dòng)態(tài)變換效果,通過(guò)jQuery結(jié)合html5的canvas技術(shù)調(diào)用時(shí)間函數(shù)實(shí)時(shí)進(jìn)行數(shù)學(xué)運(yùn)算,最終實(shí)現(xiàn)球體平拋及顏色動(dòng)態(tài)變換的效果,需要的朋友可以參考下2016-01-017款吸引人眼球的jQuery/CSS3特效實(shí)例分享
jQuery和CSS3對(duì)于web前端開(kāi)發(fā)肯定用得也比較多,接下來(lái)分享一些由jQuery和CSS3制作成的特效,希望對(duì)哪些喜歡學(xué)習(xí)特效的朋友有所幫助2013-04-04Jquery replace 字符替換實(shí)現(xiàn)代碼
Jquery replace 字符替換實(shí)現(xiàn)代碼,需要的朋友可以參考下。2010-12-12jQuery實(shí)現(xiàn)微信長(zhǎng)按識(shí)別二維碼功能
這篇文章主要介紹了jQuery實(shí)現(xiàn)微信長(zhǎng)按識(shí)別二維碼的功能,非常不錯(cuò),具有參考借鑒價(jià)值,對(duì)jquery長(zhǎng)按識(shí)別二維碼的相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧2016-08-08