亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

jQuery手機瀏覽器中拖拽動作的艱難性分析

 更新時間:2015年02月04日 10:26:41   作者:yongh701  
這篇文章主要介紹了jQuery手機瀏覽器中拖拽動作的艱難性分析,實例分析了常見的jQuery手機瀏覽器中拖拽動作解決方案,具有一定參考借鑒價值,需要的朋友可以參考下

本文實例分析了jQuery手機瀏覽器中拖拽動作的艱難性。分享給大家供大家參考。具體如下:

本想在手機網(wǎng)頁中實現(xiàn)一個如iphone可以隨意拖動的控制按鈕的,但是最后發(fā)現(xiàn)竹籃打水一場空,

雖然拖拽動作在手機瀏覽器中司空見慣,但是在手機瀏覽器中,要想實現(xiàn)可以被拖拽的組件,卻是一件不可能的事情。

先來看看在PC網(wǎng)頁中,拖拽動作是怎么做的,

首先,我們有一個按鈕,點擊有動作,一直按著不放,可以隨意拖動,就像iphone可以隨意拖動的控制按鈕一樣,

如上圖的灰色圖層,寫出來也不甚容易,

首先,要把灰色圖層的position屬性變?yōu)閍bosulte,之后在jquery腳本要實現(xiàn)的工作要點,是區(qū)分click與mousedown+mouseup這一對動作,因為click本來就等于mousedown+mouseup,但是還好,mousedown一段時間時候,馬上unbind清空圖層對cilck動作的綁定,告訴系統(tǒng),mousedown之后的動作與click無關,見如下現(xiàn)實代碼:

復制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> 
<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) { 
        /*相當于mousedown之后立即進行判斷,到底用戶有沒有按下超過1秒,有則判定為長按*/ 
        $("#mydiv").click(function() { 
            $("#mydiv").text("被點擊"); 
        }); 
        timeout = setTimeout(function() { 
            $("#mydiv").text("長按"); 
            /*以下的語句之后,用戶鼠標左鍵放起,則不會判定為click動作*/ 
            $("#mydiv").unbind("click"); 
            $("#mydiv").mousemove(function (e) { 
                /*這里是為了鼠標拖拽圖層移動的時候,鼠標剛好在圖層中間*/ 
                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動作,否則圖層會永遠綁定mousemove動作,隨著鼠標移動而移動*/ 
        $("#mydiv").unbind("mousemove"); 
        $("#mydiv").text("out");     
    });  
         
    $("#mydiv").mouseout(function() { 
        clearTimeout(timeout); 
        $("#mydiv").unbind("mousemove"); 
        $("#mydiv").text("out"); 
    }); 
}); 
</script>

之所以還要編寫mouseout事件,與之前的【jQuery實現(xiàn)長按按鈕觸發(fā)事件的方法】一文一樣,防止瀏覽器中,涂黑躲過mouseup判定的bug。
以上看起來非常地完美,因為在PC各大瀏覽器測試通過,還完美兼容IE8,實在是美如畫,

但是,一到手機中就問題大了,

僅僅在google瀏覽器中手機調(diào)試模式中,還沒有到真機上了,就無法使用了!

jquery的點擊事件在手機瀏覽器中是沒有任何問題的,但是,長按事件卻與手機上系統(tǒng)自帶的右鍵功能發(fā)生了沖突,即使換成jquery mobile中的.on("taphold",function (){});事件或者是在上面的mousedown中加入e.preventDefault();IE則用window.event.preventDefault();I禁用手機瀏覽器的自帶的菜單,也只能使長按的功能留存,拖拽是不用想了,因為拖拽最主要的函數(shù)就是mousemove動作,手機瀏覽器上根本就不支持mousemove()動作。

于是,有人提出抗議了,可以用jquery ui中的.draggable()與jquerymobile中的swipe事件,實在html5中的拖拽事件??!

然而,上述所有的解決方案都是徒勞無功,

對于jquery ui中的.draggable(),jquerymobile中的swipe事件,html5中的拖拽事件可以用瀏覽器的手機調(diào)試模式,發(fā)現(xiàn)根本就沒法拖。

希望本文所述對大家的jquery程序設計有所幫助。

相關文章

  • AspNet中使用JQuery上傳插件Uploadify詳解

    AspNet中使用JQuery上傳插件Uploadify詳解

    Uploadify是JQuery的一個上傳插件,實現(xiàn)的效果非常不錯,帶進度顯示。不過官方提供的實例時php版本的,本文將詳細介紹Uploadify在Aspnet中的使用
    2015-05-05
  • Jquery中$.post和$.ajax的用法小結(jié)

    Jquery中$.post和$.ajax的用法小結(jié)

    本節(jié)重點講的是jquery中調(diào)用ajax的4種方法中最常用的:$.post、和$ajax。如果讀者沒有javascript和jquery的知識,或者沒有ajax的概念,那么請先去問問度娘,再來讀本文。
    2015-04-04
  • jQuery根據(jù)ID獲取input、checkbox、radio、select的示例

    jQuery根據(jù)ID獲取input、checkbox、radio、select的示例

    獲取input、checkbox、radio、select的方法有很多,下面本例為大家介紹下根據(jù)ID來獲取
    2014-08-08
  • jQuery+canvas實現(xiàn)的球體平拋及顏色動態(tài)變換效果

    jQuery+canvas實現(xiàn)的球體平拋及顏色動態(tài)變換效果

    這篇文章主要介紹了jQuery+canvas實現(xiàn)的球體平拋及顏色動態(tài)變換效果,通過jQuery結(jié)合html5的canvas技術調(diào)用時間函數(shù)實時進行數(shù)學運算,最終實現(xiàn)球體平拋及顏色動態(tài)變換的效果,需要的朋友可以參考下
    2016-01-01
  • jQuery中prop()方法用法實例

    jQuery中prop()方法用法實例

    這篇文章主要介紹了jQuery中prop()方法用法,以實例形式較為詳細的分析了prop()方法的功能、定義及獲取或者設置匹配元素屬性值的各種常見使用技巧,需要的朋友可以參考下
    2015-01-01
  • jQuery?UI組件介紹

    jQuery?UI組件介紹

    這篇文章介紹了jQuery的UI組件,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2022-06-06
  • 7款吸引人眼球的jQuery/CSS3特效實例分享

    7款吸引人眼球的jQuery/CSS3特效實例分享

    jQuery和CSS3對于web前端開發(fā)肯定用得也比較多,接下來分享一些由jQuery和CSS3制作成的特效,希望對哪些喜歡學習特效的朋友有所幫助
    2013-04-04
  • 基于jquery的分頁控件(C#)

    基于jquery的分頁控件(C#)

    大家好,最近找了一個分頁控件感覺還不錯,和大家分享一下,希望大家喜歡
    2011-01-01
  • Jquery replace 字符替換實現(xiàn)代碼

    Jquery replace 字符替換實現(xiàn)代碼

    Jquery replace 字符替換實現(xiàn)代碼,需要的朋友可以參考下。
    2010-12-12
  • jQuery實現(xiàn)微信長按識別二維碼功能

    jQuery實現(xiàn)微信長按識別二維碼功能

    這篇文章主要介紹了jQuery實現(xiàn)微信長按識別二維碼的功能,非常不錯,具有參考借鑒價值,對jquery長按識別二維碼的相關知識感興趣的朋友一起學習吧
    2016-08-08

最新評論