कई सालों तक, मोबाइल ब्राउज़र touchend
और click
के बीच 300 से 350 मिलीसेकंड की देरी करते थे. ऐसा इसलिए किया जाता था, ताकि यह पता लगाया जा सके कि यह डबल-टैप है या नहीं. ऐसा इसलिए किया जाता था, क्योंकि टेक्स्ट को ज़ूम करने के लिए डबल-टैप का इस्तेमाल किया जाता था.
Android के लिए Chrome के पहले रिलीज़ होने के बाद से, पिंच-ज़ूम की सुविधा बंद होने पर यह देरी हटा दी गई थी. हालांकि, पिंच ज़ूम करना, सुलभता से जुड़ी एक अहम सुविधा है. Chrome 32 (2014 में) से, मोबाइल के लिए ऑप्टिमाइज़ की गई साइटों के लिए यह देरी खत्म हो गई है. साथ ही, पिंच-ज़ूम करने की सुविधा को हटाया नहीं गया है! इसके कुछ समय बाद, Firefox और IE/Edge ने भी ऐसा ही किया. मार्च 2016 में, iOS 9.3 में भी इसी तरह की समस्या को ठीक किया गया.
परफ़ॉर्मेंस में काफ़ी अंतर है!
तुरंत जवाब देने वाले यूज़र इंटरफ़ेस का मतलब है कि उपयोगकर्ता जवाब मिलने का इंतज़ार करने के बजाय, भरोसे के साथ हर बटन को तुरंत दबा सकता है. RAIL के बारे में जानकारी में, लोगों के रिएक्शन टाइम और वेब की परफ़ॉर्मेंस के असर के बारे में ज़्यादा जानें.
टैप में लगने वाले 300 से 350 मिलीसेकंड के इंतज़ार को हटाने के लिए, आपको अपने पेज के <head>
में ये चीज़ें जोड़नी होंगी:
<meta name="viewport" content="width=device-width">
इससे व्यूपोर्ट की चौड़ाई, डिवाइस की चौड़ाई के बराबर सेट हो जाती है. आम तौर पर, मोबाइल के लिए ऑप्टिमाइज़ की गई साइटों के लिए यह सबसे सही तरीका है. इस टैग की मदद से, ब्राउज़र यह मान लेते हैं कि आपने टेक्स्ट को मोबाइल पर पढ़ने लायक बनाया है. साथ ही, तेज़ी से क्लिक करने के लिए, ज़ूम करने के लिए दो बार टैप करने की सुविधा हटा दी जाती है.
अगर किसी वजह से यह बदलाव नहीं किया जा सकता, तो पेज पर या किसी खास एलिमेंट पर एक जैसा असर पाने के लिए, touch-action: manipulation
का इस्तेमाल किया जा सकता है:
html {
touch-action: manipulation;
}
यह तकनीक Safari में काम नहीं करती. इसलिए, व्यूपोर्ट टैग का इस्तेमाल करना ज़्यादा बेहतर होता है.
क्या ज़ूम करने के लिए दो बार टैप करने की सुविधा बंद होने से, सुलभता से जुड़ी कोई समस्या आ रही है?
नहीं. पिंच ज़ूम करने की सुविधा अब भी काम करती रहेगी. साथ ही, ओएस की सुविधाएं उन उपयोगकर्ताओं के लिए उपलब्ध हैं जिन्हें यह जेस्चर मुश्किल लगता है. Android पर, ज़ूम करने के जेस्चर की मदद से ऐसा किया जा सकता है. इस तरह के टूल, ब्राउज़र के बाहर भी काम करते हैं.
पुराने ब्राउज़र के लिए क्या करना होगा?
FT Labs का FastClick, टच इवेंट का इस्तेमाल करके क्लिक को तेज़ी से ट्रिगर करता है. साथ ही, डबल-टैप जेस्चर को हटा देता है. यह स्क्रोल और टैप के बीच अंतर करने के लिए, touchstart
और touchend
के बीच आपके फ़िंगर की गति को देखता है.
हर चीज़ में touchstart
listener जोड़ने से परफ़ॉर्मेंस पर असर पड़ता है. ऐसा इसलिए होता है, क्योंकि स्क्रोल करने जैसे लोअर-लेवल इंटरैक्शन में देरी होती है. ऐसा इसलिए होता है, क्योंकि listener को यह देखने के लिए कॉल किया जाता है कि यह event.preventDefault()
है या नहीं. अच्छी बात यह है कि FastClick उन मामलों में, लिसनर सेट करने से बचेगा जहां ब्राउज़र पहले से ही 300 मि॰से॰ की देरी को हटा देता है. इससे आपको दोनों का फ़ायदा मिलता है!