फ़ॉन्ट-डिसप्ले की मदद से फ़ॉन्ट की परफ़ॉर्मेंस को कंट्रोल करना

वेब फ़ॉन्ट के लोड होने के दौरान उसके व्यवहार को तय करना, परफ़ॉर्मेंस को बेहतर बनाने की एक अहम तकनीक हो सकती है. @font-face के लिए नए font-display डिस्क्रिप्टर की मदद से, डेवलपर यह तय कर सकते हैं कि उनके वेब फ़ॉन्ट कैसे रेंडर होंगे (या फ़ॉलबैक करेंगे). यह इस बात पर निर्भर करता है कि उन्हें लोड होने में कितना समय लगता है.

फ़ॉन्ट रेंडरिंग में आज के अंतर

वेब फ़ॉन्ट की मदद से, डेवलपर अपने प्रोजेक्ट में बेहतर टाइपोग्राफ़ी शामिल कर सकते हैं. हालांकि, अगर उपयोगकर्ता के पास पहले से कोई टाइपफ़ेस नहीं है, तो ब्राउज़र को उसे डाउनलोड करने में कुछ समय लगेगा. नेटवर्क कभी भी काम न कर सकते. इसलिए, डाउनलोड में लगने वाले समय की वजह से, उपयोगकर्ता के अनुभव पर बुरा असर पड़ सकता है. आखिर, अगर टेक्स्ट को दिखने में काफ़ी समय लगता है, तो किसी को भी इस बात से कोई फ़र्क़ नहीं पड़ेगा कि आपका टेक्स्ट कितना सुंदर है!

फ़ॉन्ट के धीरे डाउनलोड होने के कुछ जोखिमों को कम करने के लिए, ज़्यादातर ब्राउज़र एक टाइम आउट लागू करते हैं. इसके बाद, फ़ॉलबैक फ़ॉन्ट का इस्तेमाल किया जाएगा. यह एक काम की तकनीक है, लेकिन माफ़ करें, ब्राउज़र में इसे लागू करने का तरीका अलग-अलग होता है.

ब्राउज़र टाइम आउट की संख्या फ़ॉलबैक स्वैप करें
Chrome 35 और उसके बाद के वर्शन 3 सेकंड हां हां
Opera 3 सेकंड हां हां
Firefox 3 सेकंड हां हां
Internet Explorer 0 सेकंड हां हां
Safari टाइम आउट नहीं लागू नहीं लागू नहीं
  • Chrome और Firefox में तीन सेकंड का टाइम आउट होता है. इसके बाद, टेक्स्ट को फ़ॉलबैक फ़ॉन्ट में दिखाया जाता है. अगर फ़ॉन्ट डाउनलोड हो जाता है, तो आखिर में टेक्स्ट को चुने गए फ़ॉन्ट में फिर से रेंडर किया जाता है.
  • Internet Explorer में टाइम आउट की सुविधा नहीं होती. इस वजह से, टेक्स्ट तुरंत रेंडर हो जाता है. अगर अनुरोध किया गया फ़ॉन्ट अब तक उपलब्ध नहीं है, तो फ़ॉलबैक का इस्तेमाल किया जाता है. साथ ही, अनुरोध किया गया फ़ॉन्ट उपलब्ध होने के बाद, टेक्स्ट को फिर से रेंडर किया जाता है.
  • Safari में टाइम आउट की सुविधा नहीं है या कम से कम, नेटवर्क के लिए तय किए गए बुनियादी टाइम आउट से ज़्यादा का टाइम आउट नहीं है.

सबसे बुरी बात यह है कि डेवलपर के पास यह तय करने का सीमित कंट्रोल होता है कि इन नियमों का उनके ऐप्लिकेशन पर क्या असर पड़ेगा. परफ़ॉर्मेंस को ध्यान में रखकर काम करने वाला डेवलपर, शुरुआती अनुभव को तेज़ बनाने के लिए फ़ॉलबैक फ़ॉन्ट का इस्तेमाल कर सकता है. साथ ही, वह बाद में आने वाले उपयोगकर्ताओं को बेहतर वेब फ़ॉन्ट का इस्तेमाल करने की सुविधा दे सकता है. हालांकि, इसके लिए ज़रूरी है कि उपयोगकर्ता ने फ़ॉन्ट को डाउनलोड कर लिया हो. Font Loading API जैसे टूल का इस्तेमाल करके, ब्राउज़र के कुछ डिफ़ॉल्ट व्यवहारों को बदला जा सकता है और परफ़ॉर्मेंस को बेहतर बनाया जा सकता है. हालांकि, इसके लिए ज़रूरत के मुताबिक JavaScript लिखना पड़ता है. इसके बाद, इसे पेज में इनलाइन करना होता है या किसी बाहरी फ़ाइल से अनुरोध करना होता है. इससे, एचटीटीपी में अतिरिक्त इंतज़ार का समय लगता है.

इस समस्या को ठीक करने के लिए, सीएसएस वर्किंग ग्रुप ने एक नया @font-face डिस्क्रिप्टर, font-display और उससे जुड़ी प्रॉपर्टी का सुझाव दिया है. इससे यह कंट्रोल किया जा सकेगा कि डाउनलोड किया जा सकने वाला फ़ॉन्ट, पूरी तरह से लोड होने से पहले कैसे रेंडर होता है.

फ़ॉन्ट डाउनलोड होने में लगने वाला समय

फ़ॉन्ट टाइम आउट के मौजूदा व्यवहार की तरह ही, font-display फ़ॉन्ट डाउनलोड के लाइफ़टाइम को तीन मुख्य अवधियों में बांटता है. फ़िलहाल, कुछ ब्राउज़र में यह सुविधा लागू है.

  1. पहला पीरियड, फ़ॉन्ट ब्लॉक पीरियड होता है. इस दौरान, अगर फ़ॉन्ट फ़ेस लोड नहीं होता है, तो उसका इस्तेमाल करने वाले किसी भी एलिमेंट को, अदृश्य फ़ॉलबैक फ़ॉन्ट फ़ेस के साथ रेंडर करना होगा. अगर ब्लॉक किए जाने की अवधि के दौरान फ़ॉन्ट फ़ेस लोड हो जाता है, तो फ़ॉन्ट फ़ेस का सामान्य तौर पर इस्तेमाल किया जाता है.
  2. फ़ॉन्ट स्वैप पीरियड, फ़ॉन्ट ब्लॉक पीरियड के तुरंत बाद शुरू होता है. इस अवधि के दौरान, अगर फ़ॉन्ट फ़ेस लोड नहीं होता है, तो इसका इस्तेमाल करने वाले किसी भी एलिमेंट को फ़ॉलबैक फ़ॉन्ट फ़ेस के साथ रेंडर करना होगा. अगर फ़ॉन्ट फ़ेस, स्वैप की अवधि के दौरान डाउनलोड हो जाता है, तो फ़ॉन्ट फ़ेस का सामान्य तौर पर इस्तेमाल किया जाता है.
  3. फ़ॉन्ट काम न करने की अवधि, फ़ॉन्ट स्वैप की अवधि के तुरंत बाद शुरू होती है. अगर इस अवधि के शुरू होने तक फ़ॉन्ट फ़ेस लोड नहीं होता है, तो इसे 'लोड नहीं हो सका' के तौर पर मार्क कर दिया जाता है. इस वजह से, सामान्य फ़ॉन्ट फ़ॉलबैक होता है. ऐसा न होने पर, फ़ॉन्ट के सामान्य तौर पर इस्तेमाल किए जाने वाले वर्शन का इस्तेमाल किया जाता है.

इन अवधियों को समझने का मतलब है कि font-display का इस्तेमाल करके यह तय किया जा सकता है कि आपका फ़ॉन्ट कैसे रेंडर होना चाहिए. यह इस बात पर निर्भर करता है कि फ़ॉन्ट डाउनलोड किया गया है या नहीं और कब किया गया है.

आपके लिए कौनसा font-display सही है?

font-display डिस्क्रिप्टर के साथ काम करने के लिए, उसे अपने @font-face at-rules में जोड़ें:

@font-face {
    font-family: 'Arvo';
    font-display: auto;
    src: local('Arvo'), url(https://fonts.gstatic.com/s/arvo/v9/rC7kKhY-eUDY-ucISTIf5PesZW2xOQ-xsNqO47m55DA.woff2) format('woff2');
}

font-display फ़िलहाल, वैल्यू की इस रेंज के साथ काम करता है auto | block | swap | fallback | optional.

अपने-आप

auto, फ़ॉन्ट डिसप्ले की उस रणनीति का इस्तेमाल करता है जिसका इस्तेमाल यूज़र-एजेंट करता है. फ़िलहाल, ज़्यादातर ब्राउज़र में ब्लॉक जैसी डिफ़ॉल्ट रणनीति होती है.

ब्लॉक करें

block, फ़ॉन्ट फ़ेस को ब्लॉक करने की कम अवधि (ज़्यादातर मामलों में 3 सेकंड का सुझाव दिया जाता है) और अनलिमिटेड स्वैप अवधि देता है. दूसरे शब्दों में, अगर फ़ॉन्ट लोड नहीं होता है, तो ब्राउज़र पहले "अनदेखा" टेक्स्ट दिखाता है. हालांकि, फ़ॉन्ट लोड होने के बाद, वह फ़ॉन्ट फ़ेस को बदल देता है. ऐसा करने के लिए, ब्राउज़र चुने गए फ़ॉन्ट के मिलते-जुलते मेट्रिक वाला एक ऐसा फ़ॉन्ट फ़ेस बनाता है जिसमें सभी ग्लिफ़ में "इंक" नहीं होता. इस वैल्यू का इस्तेमाल सिर्फ़ तब किया जाना चाहिए, जब पेज को इस्तेमाल करने के लिए, टेक्स्ट को किसी खास टाइपफ़ेस में रेंडर करना ज़रूरी हो.

स्वैप

swap, फ़ॉन्ट फ़ेस को ब्लॉक करने के लिए शून्य सेकंड और स्वैप करने के लिए अनलिमिटेड समय देता है. इसका मतलब है कि अगर फ़ॉन्ट फ़ेस लोड नहीं होता है, तो ब्राउज़र फ़ॉलबैक के साथ तुरंत टेक्स्ट दिखाता है. हालांकि, फ़ॉन्ट फ़ेस लोड होने के बाद, उसे तुरंत बदल दिया जाता है. ब्लॉक करें की तरह ही, इस वैल्यू का इस्तेमाल सिर्फ़ तब किया जाना चाहिए, जब पेज के लिए किसी खास फ़ॉन्ट में टेक्स्ट को रेंडर करना ज़रूरी हो. हालांकि, किसी भी फ़ॉन्ट में रेंडर करने पर भी सही मैसेज दिखेगा. लोगो का टेक्स्ट, बदलने के लिए एक अच्छा विकल्प है. ऐसा इसलिए, क्योंकि किसी कंपनी के नाम को फ़ॉलबैक के तौर पर दिखाने से, मैसेज पहुंच जाएगा. हालांकि, आखिर में आपको आधिकारिक टाइपफ़ेस का इस्तेमाल करना होगा.

fallback

फ़ॉलबैक, फ़ॉन्ट फ़ेस को बहुत कम ब्लॉक अवधि देता है. ज़्यादातर मामलों में, 100 मिलीसेकंड या उससे कम का सुझाव दिया जाता है. साथ ही, यह स्वैप अवधि भी कम होती है. ज़्यादातर मामलों में, तीन सेकंड का सुझाव दिया जाता है. दूसरे शब्दों में, अगर फ़ॉन्ट लोड नहीं होता है, तो फ़ॉन्ट फ़ेस को सबसे पहले फ़ॉलबैक के साथ रेंडर किया जाता है. हालांकि, फ़ॉन्ट लोड होते ही उसे बदल दिया जाता है. हालांकि, अगर बहुत ज़्यादा समय बीत जाता है, तो पेज के बाकी समय के लिए फ़ॉलबैक का इस्तेमाल किया जाएगा. फ़ॉलबैक, मुख्य टेक्स्ट जैसी चीज़ों के लिए एक अच्छा विकल्प है. इनमें, आपको उपयोगकर्ता को जल्द से जल्द पढ़ना शुरू करने के लिए कहना है और नया फ़ॉन्ट लोड होने पर, टेक्स्ट को इधर-उधर करके उनके अनुभव में रुकावट नहीं डालनी है.

ज़रूरी नहीं

ज़रूरी नहीं विकल्प चुनने पर, फ़ॉन्ट फ़ेस को बहुत कम ब्लॉक अवधि (ज़्यादातर मामलों में 100 मिलीसेकंड या उससे कम का सुझाव दिया जाता है) और शून्य सेकंड का स्वैप पीरियड मिलता है. फ़ॉलबैक की तरह ही, यह विकल्प तब अच्छा होता है, जब डाउनलोड किया जा रहा फ़ॉन्ट, “अगर हो तो अच्छा है” के तौर पर इस्तेमाल किया जाता है, लेकिन वह अनुभव के लिए ज़रूरी नहीं होता. ज़रूरी नहीं वैल्यू से, यह ब्राउज़र पर निर्भर करता है कि फ़ॉन्ट डाउनलोड शुरू करना है या नहीं. ऐसा हो सकता है कि वह डाउनलोड शुरू न करे या कम प्राथमिकता के तौर पर डाउनलोड करे. यह इस बात पर निर्भर करता है कि ब्राउज़र को उपयोगकर्ता के लिए क्या सबसे सही लगेगा. यह सुविधा तब फ़ायदेमंद हो सकती है, जब उपयोगकर्ता के पास इंटरनेट कनेक्शन कम हो और फ़ॉन्ट डाउनलोड करना संसाधनों का सही इस्तेमाल न हो.

ब्राउज़र समर्थन

फ़िलहाल, font-display को डेस्कटॉप पर Chrome 49 में, 'वेब प्लैटफ़ॉर्म की नई सुविधाएं' फ़्लैग के पीछे रखा गया है. साथ ही, इसे Opera और Opera for Android में भी उपलब्ध कराया गया है.

डेमो

font-display को आज़माने के लिए, सैंपल देखें. परफ़ॉर्मेंस पर ध्यान देने वाले डेवलपर के लिए, यह आपके टूलबेल्ट में एक और मददगार टूल हो सकता है!