Zend फ्रेमवर्क - लेआउट

एक लेआउट कई विचारों के सामान्य भागों का प्रतिनिधित्व करता है, उदाहरण के लिए, पृष्ठ शीर्ष लेख और पाद लेख। डिफ़ॉल्ट रूप से, लेआउट में संग्रहीत किया जाना चाहिएview/layout फ़ोल्डर।

एक लेआउट कॉन्फ़िगरेशन के तहत परिभाषित किया गया है view_manager मॉड्यूल में अनुभाग ।config.php।

कंकाल आवेदन का डिफ़ॉल्ट विन्यास इस प्रकार है -

'view_manager' => array( 
   'display_not_found_reason' => true, 
   'display_exceptions' => true, 
   'doctype' => 'HTML5', 
   'not_found_template' => 'error/404', 
   'exception_template' => 'error/index', 
   'template_map' => array( 
      'layout/layout' => __DIR__ . '/../view/layout/layout.phtml', 
      'application/index/index' => __DIR__ . '/../view/application/index/index.phtml', 
      'error/404' => __DIR__ . '/../view/error/404.phtml', 
      'error/index' => __DIR__ . '/../view/error/index.phtml', 
   ), 
   'template_path_stack' => array( 
   __DIR__ . '/../view', 
),

यहां ही template_mapलेआउट निर्दिष्ट करने के लिए उपयोग किया जाता है। यदि लेआउट नहीं मिला है, तो यह एक त्रुटि लौटाएगा। आइए हम कंकाल आवेदन के मुख्य लेआउट पर एक नजर डालते हैं।

Layout.phtml

<?= $this->doctype() ?> <html lang = "en"> <head> <meta charset = "utf-8"> <?= $this->headTitle('ZF Skeleton Application')->setSeparator(' - ')>
         setAutoEscape(false) ?>
      <?= $this->headMeta() ->appendName('viewport', 'width = device-width, initial-scale = 1.0') ->appendHttpEquiv('X-UA-Compatible', 'IE = edge') ?> <!-- Le styles --> <?= $this->headLink(['rel' => 'shortcut icon', 'type' => 
         'image/vnd.microsoft.icon', 
         'href' => $this->basePath() . '/img/favicon.ico']) ->prependStylesheet($this->basePath('css/style.css')) 
         ->prependStylesheet($this->basePath('css/bootstraptheme.min.css')) ->prependStylesheet($this->basePath('css/bootstrap.min.css')) 
      ?>  
      
      <!-- Scripts --> 
      <?= $this->headScript() ->prependFile($this->basePath('js/bootstrap.min.js')) 
         ->prependFile($this->basePath('js/jquery-3.1.0.min.js')) ?> </head> <body> <nav class = "navbar navbar-inverse navbar-fixed-top" role = "navigation"> <div class = "container"> <div class = "navbar-header"> <button type = "button" class = "navbar-toggle" data- toggle = "collapse" data-target = ".navbar-collapse"> <span class = "icon-bar"></span> <span class = "icon-bar"></span> <span class = "icon-bar"></span> </button> <a class = "navbar-brand" href = "<?= $this->url('home') ?>"> 
                  <img src = "<?= $this->basePath('img/zf-logo-mark.svg') ?> " height = "28" alt = "Zend Framework <?= \Application\Module:: VERSION ?>"/> Skeleton Application </a> </div> <div class = "collapse navbar-collapse"> <ul class = "nav navbar-nav"> <li class = "active"><a href = "<?= $this->url('home') ?>">Home</a></li> 
               </ul> 
            </div> 
         </div> 
      </nav> 
   
      <div class = "container"> 
         <?= $this->content ?> <hr> <footer> <p>© 2005 - <?= date('Y') ?> by Zend Technologies Ltd. All rights reserved.</p> </footer> </div> <?= $this->inlineScript() ?> 
   </body> 
</html>

जैसा कि आप लेआउट का विश्लेषण करते हैं, यह ज्यादातर व्यू हेल्पर्स का उपयोग करता है, जिसकी हमने पिछले अध्याय में चर्चा की थी। जैसा कि हम करीब देखते हैं, लेआउट एक विशेष चर का उपयोग करता है,$this->content। यह चर महत्वपूर्ण है क्योंकि यह वास्तविक अनुरोधित पृष्ठ के दृश्य स्क्रिप्ट (टेम्पलेट) द्वारा प्रतिस्थापित किया जाएगा।

एक नया लेआउट बनाना

आइए हम अपने ट्यूटोरियल मॉड्यूल के लिए एक नया लेआउट बनाएं।

शुरुआत करने के लिए, आइए हम एक बनाते हैं tutorial.css file "सार्वजनिक / सीएसएस" निर्देशिका के तहत।

body { 
   background-color: lightblue; 
} 
h1 { 
   color: white; 
   text-align: center; 
}

एक नया लेआउट फ़ाइल बनाएँ newlayout.phtml/ myapp / मॉड्यूल / ट्यूटोरियल / देखने / लेआउट / और मौजूदा लेआउट से सामग्री की प्रतिलिपि बनाएँ। फिर, जोड़ेंtutorial.css स्टाइलशीट का उपयोग कर HeadLink हेल्पर क्लास लेआउट हेड सेक्शन के अंदर।

<?php echo $this->headLink()->appendStylesheet('/css/tutorial.css');?>

एक नया जोड़ें about नेविगेशन अनुभाग में लिंक का उपयोग कर URL सहायक।

<li><a href = "<?= $this->url('tutorial', ['action' => 'about']) ?>">About</a></li>

यह लेआउट पेज ट्यूटोरियल मॉड्यूल एप्लिकेशन के लिए सामान्य है। अद्यतन करेंview_manager ट्यूटोरियल मॉड्यूल कॉन्फ़िगरेशन फ़ाइल का अनुभाग।

'view_manager' => array( 
   'template_map' => array( 
      'layout/layout' => __DIR__ . '/../view/layout/newlayout.phtml'), 
   'template_path_stack' => array('tutorial' => __DIR__ . '/../view',), 
)

जोड़ें aboutAction में कार्य करते हैं TutorialController

public function aboutAction() { 
}

जोड़ें about.phtml myapp / मॉड्यूल / ट्यूटोरियल / देखने / ट्यूटोरियल / ट्यूटोरियल / निम्नलिखित सामग्री के साथ।

<h2>About page</h2>

अब, आप अंततः आवेदन चलाने के लिए तैयार हैं - http://localhost:8080/tutorial/about.