logo

एक्स्ट्रा ब्लॉक टाइप्स (EBT) - नया लेआउट बिल्डर अनुभव❗

एक्स्ट्रा ब्लॉक टाइप्स (EBT) - स्टाइलिश, कस्टमाइज़ेबल ब्लॉक टाइप्स: स्लाइडशो, टैब्स, कार्ड्स, एकॉर्डियन्स और कई अन्य। बैकग्राउंड, DOM बॉक्स, जावास्क्रिप्ट प्लगइन्स के लिए बिल्ट-इन सेटिंग्स। आज ही लेआउट बिल्डिंग का भविष्य अनुभव करें।

डेमो EBT मॉड्यूल्स EBT मॉड्यूल्स डाउनलोड करें

❗एक्स्ट्रा पैराग्राफ टाइप्स (EPT) - नया पैराग्राफ्स अनुभव

एक्स्ट्रा पैराग्राफ टाइप्स (EPT) - एनालॉजिकल पैराग्राफ आधारित मॉड्यूल्स का सेट।

डेमो EPT मॉड्यूल्स EPT मॉड्यूल्स डाउनलोड करें

GLightbox is a pure javascript lightbox (Colorbox alternative without jQuery)❗

It can display images, iframes, inline content and videos with optional autoplay for YouTube, Vimeo and even self-hosted videos.

Demo GLightbox Download GLightbox

स्क्रॉल
02/10/2025, by Ivan

Menu

Twig की आधिकारिक डाक्यूमेंटेशन से: «मैक्रोज़ सामान्य प्रोग्रामिंग भाषाओं में फ़ंक्शंस के समान होते हैं। ये बार-बार उपयोग होने वाले HTML पैटर्न को पुन: प्रयोज्य (reusable) एलिमेंट्स में रखने के लिए उपयोगी हैं, ताकि कोड को दोहराना न पड़े»।

{% macro input(name, value, type, size) %}
  <input type="{{ type|default('text') }}" name="{{ name }}" value="{{ value|e }}" size="{{ size|default(20) }}" />
{% endmacro %}

मैक्रोज़ PHP की नैटिव फ़ंक्शंस से कुछ तरीकों से अलग होते हैं:

  • आर्ग्युमेंट के डिफ़ॉल्ट मान default फ़िल्टर की मदद से मैक्रो के अंदर निर्धारित किए जाते हैं;
  • मैक्रो के सभी आर्ग्युमेंट वैकल्पिक होते हैं।
  • यदि अतिरिक्त पोज़िशनल आर्ग्युमेंट्स मैक्रो को पास किए जाते हैं, तो वे varargs नाम की विशेष वेरिएबल में मानों की सूची के रूप में पहुँचते हैं।

लेकिन, PHP फ़ंक्शंस की तरह, मैक्रोज़ को वर्तमान टेम्पलेट की वेरिएबल्स तक सीधा एक्सेस नहीं होता। आप पूरे कॉन्टेक्स्ट को विशेष वेरिएबल _context के रूप में आर्ग्युमेंट में पास कर सकते हैं।

मैक्रो कॉल करना

_self से

मैक्रो उसी Twig फ़ाइल में रखा जा सकता है, जहाँ से आप उसे कॉल कर रहे हैं। इस स्थिति में _self का उपयोग होता है...

{{ _self.input(name, value, type, size) }}

बाहरी फ़ाइल से

फिर भी, यह अनुशंसित है कि मैक्रोज़ को एक अलग फ़ाइल (जैसे macros.twig) में रखा जाए, ताकि वे कई टेम्पलेट्स में उपयोग किए जा सकें।

उदाहरण के लिए, एक कस्टम थीम «mytheme» में हम मैक्रो फ़ाइल यहाँ रखते हैं ...

[site_root]/themes/custom/mytheme/templates/macros.twig

नोट: मैक्रो फ़ाइल का नाम कुछ भी हो सकता है (any.twig), लेकिन उसका एक्सटेंशन .html नहीं होना चाहिए (यानी macros.html.twig काम नहीं करेगा)। फ़ाइल हमेशा «templates» डायरेक्टरी में होनी चाहिए, चाहे आप इसे कहीं भी उपयोग करें (जैसे Layout Builder लेआउट्स, जिन्हें आप .../mytheme/layouts में रखते हैं, फिर भी मैक्रो ../mytheme/templates में होना चाहिए)।

उस टेम्पलेट में जहाँ आप मैक्रो उपयोग करना चाहते हैं, यह import स्टेटमेंट जोड़ें:

{% import '@mytheme/macros.twig' as myMacros %}

@mytheme जादुई रूप से आपकी थीम की «templates» डायरेक्टरी को ढूंढ लेता है, लेकिन यदि आपकी फ़ोल्डर संरचना अतिरिक्त है, तो आपको उसे भी import स्टेटमेंट में लिखना होगा:

{% import '@mytheme/foo/bar/macros.twig' as myMacros %}

ध्यान दें कि इस डाक्यूमेंटेशन के पुराने वर्ज़न में कहा गया था कि nested डायरेक्टरी स्ट्रक्चर को परिभाषित करना ज़रूरी नहीं है, लेकिन व्यवहार अलग हो सकता है। यदि आप इसे किसी कस्टम मॉड्यूल में कर रहे हैं, तो वही तकनीक अपनाएँ, बस थीम के नाम की जगह मॉड्यूल का नाम उपयोग करें (जैसे @mycustommodule)।

फिर मैक्रो को इस तरह उपयोग करें...

{{ myMacros.input(name, value, type, size) }}

उदाहरण

Drupal 8 में मैक्रो का उपयोग मुख्य नेविगेशन बनाने के लिए किया जाता है (देखें menu.html.twig फ़ाइल)।