Zend Framework - Tata Letak

Layout mewakili bagian umum dari beberapa tampilan, misalnya, header dan footer halaman. Secara default, tata letak harus disimpan diview/layout map.

Konfigurasi Tata Letak ditentukan di bawah view_manager bagian di module.config.php.

Konfigurasi default dari aplikasi kerangka adalah sebagai berikut -

'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', 
),

Di sini template_mapdigunakan untuk menentukan tata letak. Jika tata letak tidak ditemukan, maka akan mengembalikan kesalahan. Mari kita lihat tata letak utama aplikasi kerangka.

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>

Saat Anda menganalisis tata letak, sebagian besar menggunakan view helper, yang telah kita bahas di bab sebelumnya. Saat kita melihat lebih dekat, tata letak menggunakan variabel khusus,$this->content. Variabel ini penting karena akan diganti dengan skrip tampilan (template) dari halaman yang sebenarnya diminta.

Membuat tata letak baru

Mari kita buat tata letak baru untuk modul Tutorial kita.

Untuk memulainya, mari kita buat file tutorial.css file di bawah direktori "publik / css".

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

Buat file tata letak baru newlayout.phtmldi / myapp / module / Tutorial / view / layout / dan salin konten dari layout yang ada. Kemudian, Tambahkantutorial.css stylesheet menggunakan HeadLink kelas helper di dalam bagian kepala layout.

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

Tambahkan yang baru about tautan di bagian navigasi menggunakan URL pembantu.

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

Halaman tata letak ini umum untuk aplikasi modul tutorial. Perbaruiview_manager bagian dari file konfigurasi modul tutorial.

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

Tambahkan aboutAction berfungsi di TutorialController.

public function aboutAction() { 
}

Tambahkan about.phtml di myapp / module / Tutorial / view / tutorial / tutorial / dengan konten berikut.

<h2>About page</h2>

Sekarang, Anda akhirnya siap untuk menjalankan aplikasi - http://localhost:8080/tutorial/about.