Grav - एसेट मैनेजर

इस अध्याय में आइए अध्ययन करते हैं Asset Manager। संपत्ति जोड़ने और प्रबंधित करने के लिए इंटरफ़ेस को एकीकृत करने के लिए एसेट मैनेजर को ग्रैव 0.9.0 में पेश किया गया थाJavaScript तथा CSS। थीम और प्लगइन्स से इन परिसंपत्तियों को जोड़ने से उन्नत क्षमताएं मिलेंगी जैसे किordering तथा Asset PipelineAsset Pipeline का उपयोग संपत्तियों को कम करने और संपीड़ित करने के लिए किया जाता है ताकि यह ब्राउज़र की आवश्यकताओं को कम कर दे और परिसंपत्तियों के आकार को भी कम कर दे।

एसेट मैनेजर एक वर्ग है और प्लगइन इवेंट हुक के माध्यम से Grav में उपयोग करने के लिए उपलब्ध है। आप Twig कॉल का उपयोग करके सीधे थीम में एसेट मैनेजर वर्ग का उपयोग कर सकते हैं।

विन्यास

एसेट मैनेजर में कॉन्फ़िगरेशन विकल्पों का एक सेट होता है। system.yamlफ़ाइल में डिफ़ॉल्ट मान शामिल हैं; आप इन मूल्यों को अपने में ओवरराइड कर सकते हैंuser/config/system.yaml फ़ाइल।

assets:                     # Configuration for Assets Manager (JS, CSS)
   css_pipeline: false      # The CSS pipeline is the unification of multiple CSS resources into one file
   css_minify: true         # Minify the CSS during pipelining
   css_rewrite: true        # Rewrite any CSS relative URLs during pipelining
   js_pipeline: false       # The JS pipeline is the unification of multiple JS resources into one file
   js_minify: true          # Minify the JS during pipelining

थीम्स में संपत्ति

एंटीवाटर थीम डिफ़ॉल्ट थीम के रूप में आती है जब आप Grav स्थापित करते हैं। यह एक उदाहरण दिखाता है कि आपके सीएसएस फाइलों को कैसे जोड़ा जाएbase.html.twig फ़ाइल जो इस विषय में रहती है।

{% block stylesheets %}
   {% do assets.addCss('theme://css/pure-0.5.0/grids-min.css', 103) %}
   {% do assets.addCss('theme://css-compiled/nucleus.css',102) %}
   {% do assets.addCss('theme://css-compiled/template.css',101) %}
   {% do assets.addCss('theme://css/custom.css',100) %}
   {% do assets.addCss('theme://css/font-awesome.min.css',100) %}
   {% do assets.addCss('theme://css/slidebars.min.css') %}

   {% if browser.getBrowser == 'msie' and browser.getVersion == 10 %}
      {% do assets.addCss('theme://css/nucleus-ie10.css') %}
   {% endif %}
   {% if browser.getBrowser == 'msie' and browser.getVersion >= 8 and browser.getVersion <= 9 %}
      {% do assets.addCss('theme://css/nucleus-ie9.css') %}
      {% do assets.addJs('theme://js/html5shiv-printshiv.min.js') %}
   {% endif %}
{% endblock %}
{{ assets.css() }}

उपरोक्त कोड को नीचे संक्षेप में समझाया गया है।

  • में परिभाषित क्षेत्र block टहनी टैग को टेम्प्लेट में बदला या जोड़ा जा सकता है जो एक का विस्तार करता है और आप की संख्या देख सकते हैं do assets.addCss() इस ब्लॉक के अंदर कॉल करता है।

  • {% do %} टैग आपको किसी भी आउटपुट के बिना चर को संभालने की अनुमति देता है जिसे ट्विग में ही बनाया गया है।

  • सीएसएस परिसंपत्तियों का उपयोग करके एसेट मैनेजर में जोड़ा जा सकता है addCss()तरीका। आप दूसरे पैरामीटर के रूप में एक संख्यात्मक मान पारित करके स्टाइलशीट की प्राथमिकता निर्धारित कर सकते हैं। के लिए कॉलaddCss() विधि CSS संपत्तियों से HTML टैग्स को प्रस्तुत करता है।

जावास्क्रिप्ट संपत्ति का उपयोग उसी तरह से किया जाता है जैसे सीएसएस संपत्ति। जावास्क्रिप्ट संपत्ति के भीतरblock नीचे दिखाए गए अनुसार टैग्स।

{% block javascripts %}
   {% do assets.addJs('jquery',101) %}
   {% do assets.addJs('theme://js/modernizr.custom.71422.js',100) %}
   {% do assets.addJs('theme://js/antimatter.js') %}
   {% do assets.addJs('theme://js/slidebars.min.js') %}
   {% do assets.addInineJs('alert(\'This is inline!\')') %}
{% endblock %}
{{ assets.js() }}

एसेट्स जोड़ना

निम्नलिखित तालिका विभिन्न प्रकार के ऐड मेथड्स को सूचीबद्ध करती है -

अनु क्रमांक। विधि और विवरण
1

add(asset, [options])

फ़ाइल एक्सटेंशन के आधार पर, addविधि संपत्ति से मेल खाती है। यह सीएसएस या जेएस के लिए प्रत्यक्ष तरीकों में से एक को कॉल करने के लिए एक उचित विधि है। आप का उपयोग कर सकते हैंoptionsप्राथमिकता तय करना। क्या एक परिसंपत्ति को संयोजन / पाइपलाइन में शामिल किया जाना चाहिए या पाइपलाइन विशेषता द्वारा नियंत्रित नहीं किया जाना चाहिए।

2

addCss(asset, [options])

इस विधि का उपयोग करके, आप CSS संपत्तियों में संपत्ति जोड़ सकते हैं। दूसरे पैरामीटर में प्राथमिकता के आधार पर, सूची में संपत्ति का आदेश दिया जाता है। यदि कोई प्राथमिकता निर्धारित नहीं है, तो डिफ़ॉल्ट रूप से 10 सेट है। क्या एक परिसंपत्ति को संयोजन / पाइपलाइन में शामिल किया जाना चाहिए या पाइपलाइन विशेषता द्वारा नियंत्रित नहीं किया जाना चाहिए।

3

addDirCss(directory)

इस पद्धति का उपयोग करके, आप सीएसएस परिसंपत्तियों से मिलकर एक इकाई निर्देशिका जोड़ सकते हैं जिसे वर्णानुक्रम में व्यवस्थित किया जाएगा।

4

addInlineCss(css, [options])

आप इस पद्धति का उपयोग करके इनलाइन स्टाइल टैग के अंदर CSS की एक स्ट्रिंग प्रदान कर सकते हैं।

5

addJs(asset, [options])

इस पद्धति का उपयोग करके, आप JS संपत्तियों में संपत्ति जोड़ सकते हैं। यदि प्राथमिकता सेट नहीं है, तो यह डिफ़ॉल्ट प्राथमिकता को 10 पर सेट करता है। पाइपलाइन विशेषता यह निर्धारित करती है कि किसी परिसंपत्ति को संयोजन में शामिल किया जाना चाहिए या पाइपलाइन को छोटा करना चाहिए या नहीं।

6

addInlineJs(javascript, [options])

यह विधि आपको इनलाइन स्क्रिप्ट टैग के अंदर JS की एक स्ट्रिंग जोड़ने की अनुमति देती है।

7

addDirJs(directory)

इस पद्धति का उपयोग करके, आप जेएस परिसंपत्तियों से मिलकर एक इकाई निर्देशिका जोड़ सकते हैं, जिसे वर्णानुक्रम में व्यवस्थित किया जाएगा।

8

registerCollection(name, array)

यह विधि आपको एक नाम के साथ सीएसएस या जेएस संपत्ति से युक्त एक सरणी को पंजीकृत करने की अनुमति देती है ताकि बाद में इसका उपयोग करके उपयोग किया जा सके add()तरीका। यदि आप कई थीम या प्लगइन्स का उपयोग कर रहे हैं, तो यह विधि बहुत उपयोगी है।

विकल्प

नीचे दिखाए गए अनुसार संपत्ति की सरणी को पास करने के लिए कई विकल्प हैं -

सीएसएस के लिए

  • priority - यह पूर्णांक मान लेता है और डिफ़ॉल्ट मान 100 होगा।

  • pipeline - जब किसी परिसंपत्ति को पाइपलाइन में शामिल नहीं किया जाता है, तो यह सेट हो जाता है falseमूल्य। और डिफ़ॉल्ट मान सेट किया गया हैtrue

जेएस के लिए

  • priority - पूर्णांक मान लेता है और डिफ़ॉल्ट मान 100 होगा।

  • pipeline - जब एक परिसंपत्ति पाइपलाइन में शामिल नहीं है, falseसेट है। और डिफ़ॉल्ट मान सेट किया गया हैtrue

  • loading - यह विकल्प 3 मानों का समर्थन करता है जैसे empty, async तथा defer

  • group- इसमें एक स्ट्रिंग होती है जो एक समूह के लिए विशिष्ट नाम निर्दिष्ट करती है। और डिफ़ॉल्ट मान सेट किया गया हैtrue

Example

{% do assets.addJs('theme://js/example.js', 
{'priority':101, 'pipeline':true, 'loading':'async', 'group':'top'}) %}

रेंडरिंग एसेट्स

CSS और JS संपत्तियों की वर्तमान स्थिति निम्न का उपयोग करके प्रदान की जा सकती है -

सीएसएस ()

सभी सीएसएस परिसंपत्तियों के आधार पर, जिन्हें एसेट मैनेजर में जोड़ा गया है, css()विधि HTML सीएसएस लिंक टैग से मिलकर एक सूची प्रदान करती है। पाइप लाइन विशेषता के आधार पर, सूची में मिनी फ़ाइल और व्यक्तिगत / संयुक्त संपत्ति हो सकती है।

js ()

जेएस की सभी संपत्तियों के आधार पर जो कि एसेट मैनेजर के लिए है js()विधि HTML जेएस लिंक टैग से मिलकर एक सूची प्रदान करती है। पाइप लाइन विशेषता के आधार पर, सूची में मिनी फ़ाइल और व्यक्तिगत / संयुक्त संपत्ति हो सकती है।

जिसका नाम एसेट्स रखा गया है

Grav आपको एक नाम के साथ CSS और JS संपत्तियों के संग्रह को पंजीकृत करने की अनुमति देता है, ताकि आप इसका उपयोग कर सकें addपंजीकृत नाम का उपयोग करके एसेट मैनेजर को संपत्ति। यह Grav में पूरा किया जा सकता है जिसे फीचर कहा जाता हैnamed assets। इन कस्टम संग्रह में परिभाषित किया गया हैsystem.yaml; संग्रह किसी भी विषय या प्लगइन द्वारा इस्तेमाल किया जा सकता है।

assets:
   collections:
      jquery: system://assets/jquery/jquery-2.1.3.min.js
      bootstrap:
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css
         - https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js

registerCollection() विधि का उपयोग निम्नलिखित कोड के साथ प्रोग्रामेटिक रूप से किया जा सकता है -

$assets = $this->Grav['assets'];
   $bootstrapper_bits = [https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap.min.css,
      https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/css/bootstrap-theme.min.css,
      https://maxcdn.bootstrapcdn.com/bootstrap/3.3.4/js/bootstrap.min.js];
   $assets->registerCollection('bootstrap', $bootstrap_bits);
$assets->add('bootstrap', 100);

समूहीकृत संपत्ति

Grav 0.9.43 नामक एक नई सुविधा के साथ पेश किया गया था Grouped Assets, जो आपको वैकल्पिक से मिलकर विकल्प सरणी पास करने की अनुमति देता है groupसंपत्ति जोड़ते समय। जब आप पृष्ठ के विशिष्ट भाग में कुछ JS फाइल या इनलाइन JS की आवश्यकता हो तो यह सुविधा बहुत उपयोगी है।

विकल्प सिंटैक्स का उपयोग करके, आपको नीचे दिखाए गए अनुसार संपत्ति को जोड़ते समय समूह को निर्दिष्ट करना होगा।

{% do assets.addJs('theme://js/example.js', {'priority':102, 'group':'bottom'}) %}

यदि कोई समूह किसी परिसंपत्ति के लिए निर्धारित नहीं है, तो headडिफ़ॉल्ट समूह के रूप में सेट किया गया है। यदि आप चाहते हैं कि ये संपत्तियां नीचे समूह में प्रस्तुत करें, तो आपको अपने विषय में निम्नलिखित जोड़ना होगा।

{{ assets.js('bottom') }}

स्थैतिक संपत्ति

जब भी आप एसेट मैनेजर के उपयोग के बिना संपत्ति का संदर्भ लेना चाहते हैं, तो आप इसका उपयोग कर सकते हैं url()सहायक विधि। उदाहरण के लिए, जब आप किसी छवि को विषय से संदर्भित करना चाहते हैं, तो आप निम्न सिंटैक्स का उपयोग कर सकते हैं।

<img src = "{{ url("theme://" ~ widget.image) }}" alt = "{{ widget.text|e }}" />

url() हेल्पर विधि वैकल्पिक रूप से URL को डोमेन और स्कीमा का उपयोग करने के लिए सक्षम करने के लिए दूसरा पैरामीटर लेता है true या falseमान। डिफ़ॉल्ट रूप से, मान सेट हैfalse जो केवल सापेक्ष URL प्रदर्शित करता है।

Example

url("theme://somepath/mycss.css", true)