Gesture
模組基於IOS
上的Gesture
事件的封裝,利用scale
屬性,封裝出pinch
系列事件。
原始碼版本
本文所讀的原始碼為zepto1.2.0
GitBook
《reading-zepto》
#整體架構
;(function($){ if ($.os.ios) { var gesture = {}, gestureTimeout $(document).bind('gesturestart', function(e){ ... }).bind('gesturechange', function(e){ ... }).bind('gestureend', function(e){ ... }) ;['pinch', 'pinchIn', 'pinchOut'].forEach(function(m){ $.fn[m] = function(callback){ return this.bind(m, callback) } }) } })(Zepto)
注意這裡有個判斷$.os.ios
,用來判斷是否為ios
。這個判斷需要引入設備偵測模組 Detect
。這個模組利用 userAgent
來進行裝置偵測,裡面是一大堆正規表示式,所以這個模組後面是不打算分析的了。
然後是監控gesturestart
、gesturechange
、 gestureend
事件,根據這三個事件,可以組合出pinch
、pinchIn
和pinchOut
事件。其實就是縮小和放大的手勢操作。
其中變數gesture
物件和Touch
模組中的touch
物件的作用差不多,可以先看看《讀Zepto源碼之Touch模組》對Touch
模組的分析。
parentIfText
function parentIfText(node){ return 'tagName' in node ? node : node.parentNode }
這個輔助方法是取得目標節點,如果節點不是元素節點,就用父節點作為目標節點。如果事件在文字節點或偽類元素上觸發時,會出現不是元素節點的情況。
事件
gesturestart
bind('gesturestart', function(e){ var now = Date.now(), delta = now - (gesture.last || now) gesture.target = parentIfText(e.target) gestureTimeout && clearTimeout(gestureTimeout) gesture.e1 = e.scale gesture.last = now })
如Touch
模組一樣,在gesturestart
時,也用delta
來記錄兩次start
之間的時間間隔,用gesture.target
來保存目標元素,e1
是起點時的縮放值。
gesturechange
bind('gesturechange', function(e){ gesture.e2 = e.scale })
在 gesturechange
時,更新終點 guesture.e2
的縮放值。
gestureend
if (gesture.e2 > 0) { Math.abs(gesture.e1 - gesture.e2) != 0 && $(gesture.target).trigger('pinch') && $(gesture.target).trigger('pinch' + (gesture.e1 - gesture.e2 > 0 ? 'In' : 'Out')) gesture.e1 = gesture.e2 = gesture.last = 0} else if ('last' in gesture) { gesture = {} }
如果gesture.e2
存在(不可能有小於0
的情況吧?),在起點的縮放值和終點的縮放值不相同的情況下,觸發pinch
事件;如果起點的縮放值比終點的縮放值大,則繼續觸發pinchIn
事件,則縮小效果;如果起點的縮放值比終點的縮放值小,則繼續觸發pinchOut
事件,即放大效果。
最後將 e1
、 e2
和 last
都設為 0
。
在 last
不存在的情況下(在呼叫 preventDefault
時),將 gesture
清空。
以上是Zepto源碼中Gesture模組介紹的詳細內容。更多資訊請關注PHP中文網其他相關文章!

我使用您的日常技術工具構建了功能性的多租戶SaaS應用程序(一個Edtech應用程序),您可以做同樣的事情。 首先,什麼是多租戶SaaS應用程序? 多租戶SaaS應用程序可讓您從唱歌中為多個客戶提供服務

本文展示了與許可證確保的後端的前端集成,並使用Next.js構建功能性Edtech SaaS應用程序。 前端獲取用戶權限以控制UI的可見性並確保API要求遵守角色庫

JavaScript是現代Web開發的核心語言,因其多樣性和靈活性而廣泛應用。 1)前端開發:通過DOM操作和現代框架(如React、Vue.js、Angular)構建動態網頁和單頁面應用。 2)服務器端開發:Node.js利用非阻塞I/O模型處理高並發和實時應用。 3)移動和桌面應用開發:通過ReactNative和Electron實現跨平台開發,提高開發效率。

JavaScript的最新趨勢包括TypeScript的崛起、現代框架和庫的流行以及WebAssembly的應用。未來前景涵蓋更強大的類型系統、服務器端JavaScript的發展、人工智能和機器學習的擴展以及物聯網和邊緣計算的潛力。

JavaScript是現代Web開發的基石,它的主要功能包括事件驅動編程、動態內容生成和異步編程。 1)事件驅動編程允許網頁根據用戶操作動態變化。 2)動態內容生成使得頁面內容可以根據條件調整。 3)異步編程確保用戶界面不被阻塞。 JavaScript廣泛應用於網頁交互、單頁面應用和服務器端開發,極大地提升了用戶體驗和跨平台開發的靈活性。

Python更适合数据科学和机器学习,JavaScript更适合前端和全栈开发。1.Python以简洁语法和丰富库生态著称,适用于数据分析和Web开发。2.JavaScript是前端开发核心,Node.js支持服务器端编程,适用于全栈开发。

JavaScript不需要安裝,因為它已內置於現代瀏覽器中。你只需文本編輯器和瀏覽器即可開始使用。 1)在瀏覽器環境中,通過標籤嵌入HTML文件中運行。 2)在Node.js環境中,下載並安裝Node.js後,通過命令行運行JavaScript文件。

如何在Quartz中提前發送任務通知在使用Quartz定時器進行任務調度時,任務的執行時間是由cron表達式設定的。現�...


熱AI工具

Undresser.AI Undress
人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover
用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

AI Hentai Generator
免費產生 AI 無盡。

熱門文章

熱工具

DVWA
Damn Vulnerable Web App (DVWA) 是一個PHP/MySQL的Web應用程序,非常容易受到攻擊。它的主要目標是成為安全專業人員在合法環境中測試自己的技能和工具的輔助工具,幫助Web開發人員更好地理解保護網路應用程式的過程,並幫助教師/學生在課堂環境中教授/學習Web應用程式安全性。 DVWA的目標是透過簡單直接的介面練習一些最常見的Web漏洞,難度各不相同。請注意,該軟體中

SAP NetWeaver Server Adapter for Eclipse
將Eclipse與SAP NetWeaver應用伺服器整合。

EditPlus 中文破解版
體積小,語法高亮,不支援程式碼提示功能

Dreamweaver Mac版
視覺化網頁開發工具

禪工作室 13.0.1
強大的PHP整合開發環境