Zend Framework - เค้าโครง

เค้าโครงแสดงถึงส่วนทั่วไปของหลายมุมมองเช่นส่วนหัวและส่วนท้ายของหน้า โดยค่าเริ่มต้นเค้าโครงควรเก็บไว้ในไฟล์view/layout โฟลเดอร์

การกำหนดค่าเค้าโครงถูกกำหนดภายใต้ไฟล์ view_manager ใน module.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 ภายใต้ไดเร็กทอรี“ public / css”

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

สร้างไฟล์เลย์เอาต์ใหม่ newlayout.phtmlที่ / myapp / module / Tutorial / view / layout / และคัดลอกเนื้อหาจากเค้าโครงที่มีอยู่ จากนั้นเพิ่มไฟล์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 / module / Tutorial / view / tutorial / tutorial / โดยมีเนื้อหาดังต่อไปนี้

<h2>About page</h2>

ตอนนี้คุณพร้อมที่จะเรียกใช้แอปพลิเคชันในที่สุด - http://localhost:8080/tutorial/about.