सिम्फनी - व्यू इंजन
एक दृश्य परत MVC अनुप्रयोग की प्रस्तुति परत है। यह एप्लिकेशन लॉजिक को प्रेजेंटेशन लॉजिक से अलग करता है।
जब एक नियंत्रक को HTML, CSS या अन्य किसी भी सामग्री को उत्पन्न करने की आवश्यकता होती है, तो यह कार्य को गति देने वाले इंजन को अग्रेषित करता है।
टेम्पलेट्स
टेम्प्लेट मूल रूप से टेक्स्ट फाइल होते हैं जिनका उपयोग किसी भी टेक्स्ट-आधारित दस्तावेज़ जैसे HTML, XML, आदि को उत्पन्न करने के लिए किया जाता है। इसका उपयोग समय बचाने और त्रुटियों को कम करने के लिए किया जाता है।
डिफ़ॉल्ट रूप से, टेम्पलेट दो अलग-अलग स्थानों में रह सकते हैं -
app/Resources/views/- एप्लिकेशन की व्यू डायरेक्टरी में आपके एप्लिकेशन के लेआउट और एप्लिकेशन बंडल के टेम्प्लेट हो सकते हैं। यह थर्ड पार्टी बंडल टेम्प्लेट्स को भी ओवरराइड करता है।
vendor/path/to/Bundle/Resources/views/ - प्रत्येक तीसरे पक्ष के बंडल में "संसाधन / दृश्य /" निर्देशिका में इसके टेम्पलेट शामिल हैं।
टहनी इंजन
सिम्फनी नामक शक्तिशाली शक्तिशाली भाषा का उपयोग करता है Twig। टहनी आपको बहुत आसान तरीके से संक्षिप्त और पठनीय टेम्पलेट लिखने की अनुमति देती है। टहनी टेम्प्लेट सरल हैं और PHP टैग को संसाधित नहीं करेंगे। टहनी व्हॉट्सएप नियंत्रण, सैंडबॉक्सिंग, और स्वचालित एचटीएमएल से बच निकलती है।
वाक्य - विन्यास
टहनी में तीन प्रकार के विशेष सिंटैक्स होते हैं -
{{ ... }} - एक चर या टेम्पलेट के लिए एक अभिव्यक्ति का परिणाम प्रिंट करता है।
{% ... %} - एक टैग जो टेम्पलेट के तर्क को नियंत्रित करता है। इसका उपयोग मुख्य रूप से किसी फंक्शन को निष्पादित करने के लिए किया जाता है।
{# ... #}- टिप्पणी वाक्य रचना। इसका उपयोग एकल या बहु-पंक्ति टिप्पणियों को जोड़ने के लिए किया जाता है।
टहनी आधार टेम्पलेट पर स्थित है “app/Resources/views/base.html.twig”।
उदाहरण
आइए टहनी इंजन का उपयोग करके एक सरल उदाहरण के माध्यम से चलते हैं।
StudentController.php
<?php
namespace AppBundle\Controller;
use Sensio\Bundle\FrameworkExtraBundle\Configuration\Route;
use Symfony\Component\HttpFoundation\Response;
use Symfony\Bundle\FrameworkBundle\Controller\Controller;
class StudentController extends Controller {
/**
* @Route("/student/home")
*/
public function homeAction() {
return $this->render('student/home.html.twig');
}
}
यहां ही render() विधि एक टेम्प्लेट प्रस्तुत करती है और उस सामग्री को रिस्पांस ऑब्जेक्ट में डालती है।
अब "दृश्य" निर्देशिका में जाएं और एक फ़ोल्डर बनाएं "छात्र" और उस फ़ोल्डर के अंदर एक फ़ाइल बनाएं "home.html.twig"। फ़ाइल में निम्न परिवर्तन जोड़ें।
home.html.twig
//app/Resources/views/student/home.html.twig
<h3>Student application!</h3>
आप url "http: // localhost: 8000 / student / home" का अनुरोध करके परिणाम प्राप्त कर सकते हैं।
डिफ़ॉल्ट रूप से, ट्विग टैग, फिल्टर और फ़ंक्शन की एक लंबी सूची के साथ आता है। आइए एक एक करके विस्तार से देखें।
टैग
टहनी निम्नलिखित महत्वपूर्ण टैग का समर्थन करती है -
कर
doटैग इस तरह के कार्यों को नियमित अभिव्यक्ति के रूप में अपवाद के साथ करता है कि यह कुछ भी प्रिंट नहीं करता है। इसका सिंटैक्स इस प्रकार है -
{% do 5 + 6 %}
शामिल
शामिल विवरण में एक टेम्प्लेट शामिल है और उस फ़ाइल की प्रदान की गई सामग्री को वर्तमान नामस्थान में लौटाता है। इसका सिंटैक्स इस प्रकार है -
{% include 'template.html' %}
का विस्तार
एक और एक से एक टेम्पलेट का विस्तार करने के लिए फैली हुई टैग का उपयोग किया जा सकता है। इसका सिंटैक्स इस प्रकार है -
{% extends "template.html" %}
खंड मैथा
ब्लॉक प्लेसहोल्डर के रूप में कार्य करता है और सामग्री को प्रतिस्थापित करता है। ब्लॉक नामों में अल्फ़ान्यूमेरिक वर्ण और अंडरस्कोर होते हैं। उदाहरण के लिए,
<title>{% block title %}{% endblock %}</title>
एम्बेड
embedटैग में शामिल और फैली दोनों का संयोजन होता है। यह आपको दूसरे टेम्प्लेट की सामग्री शामिल करने की अनुमति देता है। यह आपको शामिल किए गए टेम्पलेट के अंदर परिभाषित किसी भी ब्लॉक को ओवरराइड करने की अनुमति देता है, जैसे कि टेम्पलेट को बढ़ाते समय। इसका सिंटैक्स इस प्रकार है -
{% embed “new_template.twig” %}
{# These blocks are defined in “new_template.twig" #}
{% block center %}
Block content
{% endblock %}
{% endembed %}
फ़िल्टर
फ़िल्टर अनुभाग आपको टेम्पलेट डेटा के ब्लॉक पर नियमित ट्विग फ़िल्टर लागू करने की अनुमति देते हैं। उदाहरण के लिए,
{% filter upper %}
symfony framework
{% endfilter %}
यहां, पाठ को ऊपरी मामले में बदल दिया जाएगा।
के लिये
Forलूप प्रत्येक आइटम को एक क्रम में लाते हैं। उदाहरण के लिए,
{% for x in 0..10 %}
{{ x }}
{% endfor %}
अगर
ifTwig में कथन PHP के समान है। अभिव्यक्ति सही या गलत का मूल्यांकन करती है। उदाहरण के लिए,
{% if value == true %}
<p>Simple If statement</p>
{% endif %}
फिल्टर
टहनी में फिल्टर होते हैं। इसका उपयोग सामग्री को संशोधित करने से पहले किया जाता है। निम्नलिखित कुछ उल्लेखनीय फिल्टर हैं।
लंबाई
लंबाई फ़िल्टर एक स्ट्रिंग की लंबाई लौटाता है। इसका सिंटैक्स इस प्रकार है -
{% if name|length > 5 %}
...
{% endif %}
कम
निम्न फ़िल्टर एक मान को लोअरकेस में परिवर्तित करता है। उदाहरण के लिए,
{{ 'SYMFONY'|lower }}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
symfony
इसी तरह, आप ऊपरी मामले के लिए कोशिश कर सकते हैं।
बदलने के
प्लेसहोल्डर्स को प्रतिस्थापित करके फ़िल्टर दिए गए स्ट्रिंग को प्रतिस्थापित करता है। उदाहरण के लिए,
{{ "tutorials point site %si% and %te%."|replace({'%si%': web, '%te%': "site"}) }}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
tutorials point website
शीर्षक
शीर्षक फ़िल्टर मान का शीर्षक संस्करण देता है। उदाहरण के लिए,
{{ 'symfony framework '|title }}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Symfony Framework
तरह
सॉर्ट फ़िल्टर एक सरणी को सॉर्ट करता है। इसका सिंटैक्स इस प्रकार है -
{% for user in names|sort %}
...
{% endfor %}
ट्रिम
ट्रिम फिल्टर एक स्ट्रिंग की शुरुआत और अंत से व्हाट्सएप (या अन्य वर्ण) को ट्रिम करता है। उदाहरण के लिए,
{{ ' Symfony! '|trim }}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Symfony!
कार्यों
टहनी कार्यों का समर्थन करती है। इसका उपयोग किसी विशेष परिणाम को प्राप्त करने के लिए किया जाता है। निम्नलिखित कुछ महत्वपूर्ण कार्य हैं।
गुण
attributeफ़ंक्शन का उपयोग किसी चर के "गतिशील" विशेषता तक पहुंचने के लिए किया जा सकता है। इसका सिंटैक्स इस प्रकार है -
{{ attribute(object, method) }}
{{ attribute(object, method, arguments) }}
{{ attribute(array, item) }}
उदाहरण के लिए,
{{ attribute(object, method) is defined ? 'Method exists' : 'Method does not exist' }}
स्थिर
लगातार फ़ंक्शन निर्दिष्ट स्ट्रिंग के लिए निरंतर मान लौटाता है। उदाहरण के लिए,
{{ constant('Namespace\\Classname::CONSTANT_NAME') }}
चक्र
मानों की एक सरणी पर चक्र फ़ंक्शन चक्र। उदाहरण के लिए,
{% set months = [‘Jan’, ‘Feb’, ‘Mar’] %}
{% for x in 0..12 %}
{ cycle(months, x) }}
{% endfor %}
दिनांक
दिनांक तुलना की अनुमति देने के लिए एक तर्क को एक तिथि में परिवर्तित करता है। उदाहरण के लिए,
<p>Choose your location before {{ 'next Monday'|date('M j, Y') }}</p>
यह निम्नलिखित परिणाम का उत्पादन करेगा -
Choose your location before May 15, 2017
तर्क PHP की समर्थित तिथि और समय स्वरूपों में से एक में होना चाहिए।
आप दूसरे तर्क के रूप में एक टाइमज़ोन पास कर सकते हैं।
ढेर
डंप फ़ंक्शन एक टेम्पलेट चर के बारे में जानकारी डंप करता है। उदाहरण के लिए,
{{ dump(user) }}
मैक्स
अधिकतम फ़ंक्शन किसी अनुक्रम का सबसे बड़ा मान लौटाता है। उदाहरण के लिए,
{{ max(1, 5, 9, 11, 15) }}
मिनट
न्यूनतम फ़ंक्शन किसी अनुक्रम का सबसे छोटा मान लौटाता है। उदाहरण के लिए,
{{ min(1, 3, 2) }}
शामिल
फ़ंक्शन में शामिल टेम्प्लेट की सामग्री प्रदान करता है। उदाहरण के लिए,
{{ include('template.html') }}
बिना सोचे समझे
यादृच्छिक फ़ंक्शन एक यादृच्छिक मान उत्पन्न करता है। उदाहरण के लिए,
{{ random([‘Jan’, ‘Feb’, ‘Mar’, ‘Apr’]) }}
{# example output: Jan #}
रेंज
रेंज फ़ंक्शन एक सूची देता है जिसमें पूर्णांकों की अंकगणितीय प्रगति होती है। उदाहरण के लिए,
{% for x in range(1, 5) %}
{{ x }},
{% endfor %}
यह निम्नलिखित परिणाम का उत्पादन करेगा -
1,2,3,4,5
लेआउट
एक लेआउट कई विचारों के सामान्य भागों का प्रतिनिधित्व करता है, उदाहरण के लिए, पृष्ठ शीर्ष लेख और पाद लेख।
टेम्प्लेट इनहेरिटेंस
एक टेम्पलेट का उपयोग दूसरे द्वारा किया जा सकता है। हम इसे टेम्पलेट इनहेरिटेंस कॉन्सेप्ट का उपयोग करके प्राप्त कर सकते हैं। टेम्प्लेट इनहेरिटेंस आपको एक आधार "लेआउट" टेम्पलेट बनाने की अनुमति देता है जिसमें वेब साइट के सभी सामान्य तत्व शामिल हैं जिन्हें ब्लॉक के रूप में परिभाषित किया गया है।
आइए टेम्पलेट विरासत के बारे में अधिक समझने के लिए एक सरल उदाहरण लेते हैं।
उदाहरण
"ऐप / संसाधन / विचार / base.html.twig" पर स्थित बेस टेम्प्लेट पर विचार करें। फ़ाइल में निम्न परिवर्तन जोड़ें।
base.html.twig
<!DOCTYPE html>
<html>
<head>
<meta charset = "UTF-8">
<title>{% block title %}Parent template Layout{% endblock %}</title>
</head>
</html>
अब "ऐप / संसाधन / विचार / डिफ़ॉल्ट / index.html.twig" पर स्थित इंडेक्स टेम्प्लेट फ़ाइल पर जाएं । इसमें निम्नलिखित परिवर्तन जोड़ें।
index.html.twig
{% extends 'base.html.twig' %}
{% block title %}Child template Layout{% endblock %}
यहां ही {% extends %}टैग पहले टेम्प्लेट इंजन को बेस टेम्पलेट का मूल्यांकन करने के लिए सूचित करता है, जो लेआउट सेट करता है और ब्लॉक को परिभाषित करता है। बाल टेम्पलेट तब प्रदान किया जाता है। एक बाल टेम्पलेट बेस लेआउट का विस्तार कर सकता है और शीर्षक ब्लॉक को ओवरराइड कर सकता है। अब, url "http: // localhost: 8000" का अनुरोध करें और आप इसका परिणाम प्राप्त कर सकते हैं।
संपत्ति
एसेट URL पीढ़ी और सीएसएस स्टाइलशीट, जावास्क्रिप्ट फ़ाइलों और छवि फ़ाइलों जैसी वेब परिसंपत्तियों के संस्करण का प्रबंधन करता है।
जावास्क्रिप्ट
जावास्क्रिप्ट फ़ाइलों को शामिल करने के लिए, का उपयोग करें javascripts किसी भी टेम्प्लेट में टैग।
{# Include javascript #}
{% block javascripts %}
{% javascripts '@AppBundle/Resources/public/js/*' %}
<script src="{{ asset_url }}"></script>
{% endjavascripts %}
{% endblock %}
स्टाइलशीट
स्टाइलशीट फ़ाइलों को शामिल करने के लिए, का उपयोग करें stylesheets किसी भी टेम्प्लेट में टैग
{# include style sheet #}
{% block stylesheets %}
{% stylesheets 'bundles/app/css/*' filter = 'cssrewrite' %}
<link rel = "stylesheet" href="{{ asset_url }}" />
{% endstylesheets %}
{% endblock %}
इमेजिस
एक छवि शामिल करने के लिए, आप छवि टैग का उपयोग कर सकते हैं। इसे निम्नानुसार परिभाषित किया गया है।
{% image '@AppBundle/Resources/public/images/example.jpg' %}
<img src = "{{ asset_url }}" alt = "Example" />
{% endimage %}
यौगिक संपत्ति
आप कई फ़ाइलों को एक में जोड़ सकते हैं। यह HTTP अनुरोधों की संख्या को कम करने में मदद करता है, और अधिक से अधिक फ्रंट-एंड प्रदर्शन का उत्पादन करता है।
{% javascripts
'@AppBundle/Resources/public/js/*'
'@AcmeBarBundle/Resources/public/js/form.js'
'@AcmeBarBundle/Resources/public/js/calendar.js' %}
<script src = "{{ asset_url }}"></script>
{% endjavascripts %}