ज़ेंड फ्रेमवर्क - लेयर देखें

एक दृश्य परत MVC अनुप्रयोग की प्रस्तुति परत है। यह एप्लिकेशन लॉजिक को प्रेजेंटेशन लॉजिक से अलग करता है। एक सामान्य PHP वेब अनुप्रयोग में, सभी व्यावसायिक तर्क और डिज़ाइन एक दूसरे से जुड़े हुए हैं। इंटरमिक्सिंग एक छोटी परियोजना में तेजी से विकास को सक्षम बनाता है। लेकिन, यह बड़ी परियोजना में बुरी तरह विफल रहता है, जहां उच्च स्तर की वास्तुकला शामिल है। वेब एप्लिकेशन के डिज़ाइन को बदलने के लिए, एक डेवलपर को व्यावसायिक तर्क पर भी काम करना होगा। यह भयावह हो सकता है जिसके परिणामस्वरूप व्यापारिक तर्क टूट सकते हैं।

Zend फ्रेमवर्क एक अच्छी तरह से विचार, स्वच्छ, लचीला और विस्तार योग्य दृश्य परत प्रदान करता है। दृश्य परत एक अलग मॉड्यूल के रूप में उपलब्ध है,Zend/View और के साथ ठीक एकीकृत Zend/Mvcमापांक। ज़ेंड व्यू लेयर को एक-दूसरे के साथ अच्छी तरह से बातचीत करते हुए कई घटकों में विभाजित किया गया है।

इसके विभिन्न घटक इस प्रकार हैं -

  • Variables Containers - होल्ड्स लेयर के डेटा को देखते हैं।

  • View Models - परिवर्तनीय कंटेनरों और डिजाइन टेम्पलेट को धारण करता है।

  • Renderers - देखें मॉडल से प्रक्रिया डेटा और टेम्पलेट और एक डिजाइन प्रतिनिधित्व करते हैं, शायद अंतिम HTML आउटपुट।

  • Resolvers - व्यू मॉडल में उपलब्ध टेम्पलेट को इस तरह से हल करता है कि रेंडरर उपभोग कर सकता है।

  • View (Zend\View\View) - मैप्स रेंडरर को रिक्वेस्ट करते हैं और फिर रेंडरर को जवाब देते हैं।

  • Rendering Strategies - रेंडर करने के लिए मानचित्र अनुरोध करने के लिए देखें द्वारा उपयोग किया जाता है।

  • Response Strategies - प्रतिक्रिया के लिए मानचित्र रेंडरर को देखें द्वारा उपयोग किया जाता है।

दृश्य परत, View प्रक्रियाओं ViewModel, टेम्पलेट का उपयोग कर हल करता है a Resolver, का उपयोग कर इसे प्रस्तुत करना Rendering Strategy और अंत में इसका उपयोग करके आउटपुट करता है Response Renderer

परत विन्यास देखें

नियंत्रक की तरह, एक दृश्य परत को मॉड्यूल की कॉन्फ़िगरेशन फ़ाइल में कॉन्फ़िगर किया जा सकता है जिसे कहा जाता है - module.config.php। मुख्य कॉन्फ़िगरेशन निर्दिष्ट करना है कि टेम्पलेट कहाँ रखे जा रहे हैं। यह निम्नलिखित मॉड्यूल "mod.config.php" में जोड़कर पूरा किया जा सकता है।

'view_manager' => [ 
   'template_path_stack' => ['tutorial' => __DIR__ . '/../view',], 
]

डिफ़ॉल्ट रूप से, दृश्य परत में इसके सभी घटकों के लिए एक डिफ़ॉल्ट व्यवहार होता है। उदाहरण के लिए, एViewModel"लोअरकेस-मॉड्यूल-नाम / लोअरकेस-कंट्रोलर-नेम / लोअरकेस-एक्शन-नेम" नियम द्वारा टेम्प्लेट रूट के अंदर एक कंट्रोलर की कार्रवाई का टेम्पलेट नाम हल करता है। हालाँकि, इसे ओवरराइड किया जा सकता हैsetTemplate() ViewModel की विधि।

नियंत्रकों और देखें परत

डिफ़ॉल्ट रूप से, किसी भी नियंत्रक को व्यू लेयर पर कोई डेटा भेजने की आवश्यकता नहीं होती है। यह उचित स्थान पर टेम्पलेट लिखने के लिए पर्याप्त है।

उदाहरण के लिए, हमारे उदाहरण में, TutorialControllerटेम्पलेट को रखा जाना चाहिए myapp/module/Tutorial/view/tutorial/tutorial/index.phtmlindex.phtmlPHP आधारित टेम्पलेट को संदर्भित करता है और इसे PHPRenderer द्वारा प्रदान किया जाएगा। अन्य रेंडरर्स जैसे हैंJsonRenderer के लिये json उत्पादन और FeedRenderer के लिये rss तथा atom उत्पादन।

पूरी लिस्टिंग इस प्रकार है -

<?php  
namespace Tutorial\Controller;  
use Zend\Mvc\Controller\AbstractActionController; 
use Zend\View\Model\ViewModel;  
class TutorialController extends AbstractActionController { 
   public function indexAction() { 
   } 
}

Zend एप्लीकेशन टेम्प्लेट

<div class = "row content"> 
   <h3>This is my first Zend application</h3> 
</div>

अंत में, हमने सफलतापूर्वक पूरा कर लिया है Tutorial मॉड्यूल और हम url का उपयोग करके इसे एक्सेस कर सकते हैं - http://localhost:8080/tutorial

लेयर को देखने के लिए डेटा पास करना

डेटा को व्यू लेयर पर भेजने का सबसे सरल तरीका है इसका उपयोग करना ViewModelतर्क। बदल गयाindexAction विधि इस प्रकार है -

public function indexAction() { 
   $view = new ViewModel([ 'message' => 'Hello, Tutorial' ]); return $view; 
}

अब, बदलो index.phtml फाइल इस प्रकार है -

<div class = "row content"> 
   <h3>This is my first Zend application</h3> 
   <h4><?php echo $this->message?></h4> 
</div>

सहायकों को देखें

टेम्पलेट्स में उपयोग किए जाने वाले छोटे, परमाणु कार्यों को लिखने के लिए एक व्यू हेल्पर का उपयोग किया जाता है। Zend फ्रेमवर्क एक इंटरफ़ेस प्रदान करता है, मानक दृश्य सहायकों को लिखने के लिए Zend \ View \ Helper \ HelperInterface।

एक हेल्परइंटरफेस के बस दो तरीके हैं,

  • setView() - यह विधि एक Zend \ View \ Renderer \ RendererInterface उदाहरण / कार्यान्वयन को स्वीकार करती है।

  • getView() - इसका उपयोग उस उदाहरण को पुनः प्राप्त करने के लिए किया जाता है।

की पूरी कोड सूची HelperInterface इस प्रकार है -

namespace Zend\View\Helper;  
use Zend\View\Renderer\RendererInterface as Renderer;  
interface HelperInterface { 
   /** 
      * Set the View object 
      * 
      * @param  Renderer $view 
      * @return HelperInterface 
   */ 
   public function setView(Renderer $view);  
   /** 
      * Get the View object 
      * 
      * @return Renderer 
   */ 
   public function getView(); 
}

अपने दृश्य स्क्रिप्ट में एक सहायक का उपयोग करने के लिए, इसका उपयोग करके पहुंचें $this->helperName()

बिल्ट-इन हेल्पर्स

Zend फ्रेमवर्क विभिन्न प्रयोजनों के लिए बहुत सारे इनबिल्ट हेल्पर फ़ंक्शन प्रदान करता है। में उपलब्ध कुछ व्यू हेल्पर्सzend-mvc इस प्रकार हैं -

यूआरएल

URL हेल्पर का उपयोग एप्लिकेशन में परिभाषित मार्गों से मेल खाने वाले URL को उत्पन्न करने के लिए किया जाता है।

URL सहायक की परिभाषा है -

$this->url($name, $params, $options, $reuseMatchedParameters)

उदाहरण के लिए, ट्यूटोरियल मॉड्यूल में, मार्ग का नाम दिया गया है tutorial और इसके दो मापदंड हैं action तथा id। हम नीचे दिखाए गए अनुसार दो अलग URL बनाने के लिए URL सहायक का उपयोग कर सकते हैं -

<a href = "<? = $this->url('tutorial'); ?>">Tutorial Index</a>  
<a href = "<? = $this->url('tutorial', ['action' => 'show', 'id' =>10]); ?>"> 
   Details of Tutorial #10 
</a>

परिणाम इस प्रकार होगा -

<a href = "/tutorial">Tutorial Index</a>  
<a href = "/tutorial/show/10"> Details of Tutorial #10</a>

प्लेसहोल्डर

प्लेसहोल्डर सहायक का उपयोग स्क्रिप्ट और दृश्य उदाहरणों के बीच सामग्री को बनाए रखने के लिए किया जाता है। यह आरंभ में डेटा सेट करने का विकल्प प्रदान करता है और फिर बाद के चरणों में इसका उपयोग करता है।

उदाहरण के लिए, हम सेट कर सकते हैं, कह सकते हैं company name और फिर इसे अन्य सभी स्थानों पर उपयोग करें।

<?php $this->placeholder('companyname')->set("TutorialsPoint") ?>  
<?= $this->placeholder('companyname'); ?>

एक प्लेसहोल्डर PHP सरणी और ऑब्जेक्ट से जटिल सामग्री उत्पन्न करने के लिए कुछ उन्नत विकल्प प्रदान करता है। इसमें टेम्पलेट के कुछ सेक्शन को कैप्चर करने का भी विकल्प है।

उदाहरण के लिए, निम्न कोड टेम्पलेट परिणाम को बीच में पकड़ता है और इसे स्टोर करता है productlist प्लेसहोल्डर।

Class – Product

class Product { 
   public $name; 
   public $description; 
}

Controller

$p1 = new Product(); 
$p1->name = 'Car'; $p1->description = 'Car';  
$p2 = new Product(); $p2->name = 'Cycle'; 
$p2->description = 'Cycle'; $view = new ViewModel(['products' => $products]);

Template

<!-- start capture --> 
<?php $this->placeholder('productlist')->captureStart(); 
   foreach ($this->products as $product): ?> 
<div> 
   <h2><?= $product->name ?></h2> <p><?= $product->description ?></p> 
</div> 
<?php endforeach; ?> 
<?php $this->placeholder('productlist')->captureEnd() ?> <!-- end capture --> <?= $this->placeholder('productlist') ?>

Result

<div class = "foo"> 
   <h2>Car</h2> 
   <p>Car</p> 
</div>
<div class = "foo"> 
   <h2>Cycle</h2> 
   <p>Cycle</p> 
</div>

doctype

Doctype हेल्पर का उपयोग विभिन्न HTML सिद्धांतों को उत्पन्न करने के लिए किया जाता है। यह ठोस कार्यान्वयन हैPlaceholderसहायक। सिद्धांत को बूटस्ट्रैप फ़ाइल और विन्यास फाइल में सेट किया जा सकता है।

मूल उपयोग नीचे दिखाया गया है -

Application Bootstrap file

use Zend\View\Helper\Doctype;  
$doctypeHelper = new Doctype(); $doctypeHelper->doctype('XHTML5');

Module Configuration

// module/Application/config/module.config.php: 
return [ 
   /* ... */ 
   'view_manager' => [ 
      'doctype' => 'html5', 
      /* ... */ 
   ], 
];

Template

<?php echo $this->doctype() ?>

HeadTitle

HTML शीर्षक तत्व को उत्पन्न करने के लिए HeadTitle सहायक का उपयोग किया जाता है। इसका ठोस क्रियान्वयन हैPlaceholderसहायक। Zend मॉड्यूल विन्यास फाइल में शीर्षक सेट करने के लिए एक विकल्प प्रदान करता है और इसे किसी भी स्तर पर सेट किया जा सकता है जैसे साइट, मॉड्यूल, कंट्रोलर, एक्शन, आदि। HeadTitle के लिए एक आंशिक कोड निम्नानुसार है -

Module

headTitleHelper->append($action); 
$headTitleHelper->append($controller); 
$headTitleHelper->append($module); 
$headTitleHelper->append($siteName);

Template

<?= $this->headTitle() ?>

Result

action - controller - module - Zend Framework

HeadMeta

हेडमाटा हेल्पर का उपयोग html मेटा टैग बनाने के लिए किया जाता है। यह प्लेसहोल्डर हेल्पर का एक ठोस कार्यान्वयन है।

Template -

<?php 
   $this->headMeta()->appendName('keywords', 'turorialspoint, zend framework, php');  
   echo $this->headMeta() 
?>

Result

<meta name = "keywords" content = "tutorialspoint, zend framework, php" />

Headlink

HeadLink सहायक बाहरी संसाधनों को शामिल करने के लिए html लिंक उत्पन्न करने के लिए उपयोग किया जाता है। यह प्लेसहोल्डर हेल्पर का ठोस कार्यान्वयन है।

Template

<?php 
   // setting links in a view script: 
   $this->headLink(['rel' => 'icon', 'href' => '/img/favicon.ico'], 'PREPEND') 
      ->appendStylesheet('/styles/site.css') 
      ->prependStylesheet('/styles/mystyle.css', 'screen', true, ['id' => 'mystyle']);  
   
   // rendering the links from the layout: 
   echo $this->headLink(); 
?>

Result

<link href = "/styles/mystyle.css" media = "screen" rel = "stylesheet" 
   type = "text/css" id = "mystyle"> 
<link href = "/img/favicon.ico" rel = "icon"> 
<link href = "/styles/site.css" media = "screen" rel = "stylesheet" type = "text/css">

HeadStyle

HeadStyle हेल्पर का उपयोग इनलाइन CSS स्टाइल उत्पन्न करने के लिए किया जाता है। यह प्लेसहोल्डर हेल्पर का ठोस कार्यान्वयन है।

Template

<?php $this->headStyle()->appendStyle($styles); ?> <?php echo $this->headStyle() ?>

HeadScript

हेडस्क्रिप्ट का उपयोग इनलाइन स्क्रिप्ट को उत्पन्न करने या बाहरी स्क्रिप्ट को शामिल करने के लिए किया जाता है। यह प्लेसहोल्डर हेल्पर का ठोस कार्यान्वयन है।

Template

<? $this->headScript()->appendFile(‘/js/sample.js’);?> <?php echo $this->headScript() ?>

InlineScript

इनलाइनस्क्रिप्ट का उपयोग html टेम्पलेट के सिर और शरीर दोनों अनुभागों में एक स्क्रिप्ट उत्पन्न करने के लिए किया जाता है। यह हेडस्क्रिप्ट से लिया गया है।

HTMLList

HTMLList का उपयोग ऑर्डर और अनऑर्डर की गई सूची को जेनरेट करने के लिए किया जाता है। HTMLList की परिभाषा इस प्रकार है -

Definition

htmlList($items, $ordered, $attribs, $escape)

Template

$items = [ '2015', ['March', 'November'], '2016', ]; echo $this->htmlList($items);

Result

<ul> 
   <li>2015 
      <ul> 
         <li>March</li> 
         <li>November</li> 
      </ul> 
   </li> 
   <li>2016</li> 
</ul>

चक्र

लूप वातावरण में विकल्प उत्पन्न करने के लिए एक चक्र का उपयोग किया जाता है। इसका कार्य, अगला और प्रचलित कार्य है।

Controller

$view = new ViewModel(['message' => 'Hello, Tutorial', 'data' => array('One', 'Two')]);

Template

<?php $this->cycle()->assign(['#F0F0F0', '#FFF'], 'colors'); ?> <table> <?php foreach ($this->data as $datum): ?> <tr style = "background-color: <?= $this->cycle()->setName('colors')>next() ?>">
      <td><?= $this->escapeHtml($datum) ?></td>
   </tr>
   <?php endforeach ?>
</table>

Result

<table> 
   <tr style = "background-color: #F0F0F0"> 
      <td>One</td> 
   </tr> 
   <tr style = "background-color: #FFF"> 
      <td>Two</td> 
   </tr> 
</table>

कुछ अन्य महत्वपूर्ण निर्मित सहायक इस प्रकार हैं -

  • BasePath - बेसपाथ का उपयोग एप्लिकेशन के रूट के सार्वजनिक फ़ोल्डर का पथ उत्पन्न करने के लिए किया जाता है।

  • Partial - आंशिक का उपयोग अपने स्वयं के चर दायरे में एक विशिष्ट टेम्पलेट को प्रस्तुत करने के लिए किया जाता है।

  • PartialLoop - पार्टियललोप आंशिक की तरह है, लेकिन लूपिंग वातावरण में उपयोग किया जाता है।

  • Identity - पहचान का उपयोग प्रमाणीकरण सेवा से लॉग-इन उपयोगकर्ता की पहचान को पुनः प्राप्त करने के लिए किया जाता है।

  • JSON- JSON का उपयोग एक आरामदायक वातावरण में किया जाता है, जहां आउटपुट JSON प्रारूप में होता है। यह उचित HTTP हेडर का उत्सर्जन करता है और लेआउट अवधारणा को निष्क्रिय करता है।

Zend फ्रेमवर्क में अभी भी बहुत से सहायक उपलब्ध हैं जैसे कि i18n helper, form helpers, pagination helpers, navigation helpers, आदि।

व्यू हेल्पर्स बनाना

Zend फ्रेमवर्क एक अंतर्निर्मित प्रदान करता है AbstractHelper क्रियान्वयन HelperInterface लिखने वालों को देखने के लिए।

एक नया सहायक लिखने में शामिल कदम इस प्रकार हैं -

  • Step 1 - कक्षा Zend \ View \ Helper \ AbstractHelper बढ़ाएँ।

  • Step 2 - ओवरराइड करें __invoke() समारोह।

  • Step 3 - में विन्यास सेट करें module.config.php file

  • Step 4 - व्यू स्क्रिप्ट में हेल्पर का इस्तेमाल करें।

अब हम एक बनाते हैं TestHelper

पर हेल्पर फ़ोल्डर बनाएँ myapp/module/Tutorial/src/View directory। लिखोTestHelper हेल्पर निर्देशिका के अंदर, TestHelper.php

पूरी लिस्टिंग इस प्रकार है -

<?php  
namespace Tutorial\View\Helper; 
use Zend\View\Helper\AbstractHelper; 
class TestHelper extends AbstractHelper { 
   public function __invoke() { 
      $output = "I am from test helper"; return htmlspecialchars($output, ENT_QUOTES, 'UTF-8'); 
   } 
}

में कॉन्फ़िगरेशन सेट करें module.config.php

'view_helpers' => [ 
   'aliases' => [ 
      'testHelper' => View\Helper\TestHelper::class, 
   ], 
   'factories' => [ 
      View\Helper\TestHelper::class => InvokableFactory::class, 
   ],
],

नव निर्मित का उपयोग करें TestHelper में about स्क्रिप्ट देखें।

<?= $this->testHelper() ?>