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

jQuery手機(jī)瀏覽器中拖拽動(dòng)作的艱難性分析

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

本文實(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í)代碼:

復(fù)制代碼 代碼如下:
<!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) { 
        /*相當(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ì)有所幫助。

相關(guān)文章

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

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

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

    Jquery中$.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-04
  • jQuery根據(jù)ID獲取input、checkbox、radio、select的示例

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

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

    jQuery+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-01
  • jQuery中prop()方法用法實(shí)例

    jQuery中prop()方法用法實(shí)例

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

    jQuery?UI組件介紹

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

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

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

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

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

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

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

    jQuery實(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

最新評(píng)論