Zend Framework - Lihat Layer

Tampilan Lapisan adalah lapisan presentasi aplikasi MVC. Ini memisahkan logika aplikasi dari logika presentasi. Dalam aplikasi web PHP yang khas, semua logika bisnis dan desain saling bercampur. Pencampuran memungkinkan pengembangan yang lebih cepat dalam proyek kecil. Tapi, itu gagal total dalam proyek besar, di mana banyak arsitektur tingkat tinggi terlibat. Untuk mengubah desain aplikasi web, pengembang perlu mengerjakan logika bisnis juga. Ini mungkin bencana yang mengakibatkan putusnya logika bisnis.

Zend Framework menyediakan lapisan Tampilan yang dipikirkan dengan matang, bersih, fleksibel, dan dapat diperpanjang. Lapisan Tampilan tersedia sebagai modul terpisah,Zend/View dan terintegrasi dengan baik Zend/Mvcmodul. Zend View Layer dipisahkan menjadi beberapa komponen yang berinteraksi dengan baik satu sama lain.

Berbagai komponennya adalah sebagai berikut -

  • Variables Containers - Menyimpan data lapisan tampilan.

  • View Models - Memegang Variable Containers dan template desain.

  • Renderers - Memproses data dan template dari View Model dan mengeluarkan representasi desain, mungkin keluaran html akhir.

  • Resolvers - Mengatasi template yang tersedia di Model Tampilan sedemikian rupa sehingga Renderer dapat menggunakan.

  • View (Zend\View\View) - Memetakan permintaan ke perender dan kemudian perender untuk merespons.

  • Rendering Strategies - Digunakan oleh View untuk memetakan permintaan ke penyaji.

  • Response Strategies - Digunakan oleh View untuk memetakan renderer ke respon.

Lapisan tampilan, View memproses ViewModel, menyelesaikan template menggunakan file Resolver, render menggunakan Rendering Strategy dan akhirnya mengeluarkannya menggunakan Response Renderer.

Lihat Konfigurasi Lapisan

Seperti pengontrol, lapisan Tampilan dapat dikonfigurasi dalam file konfigurasi modul yang disebut sebagai - module.config.php. Konfigurasi utama adalah untuk menentukan di mana templat akan ditempatkan. Ini dapat dilakukan dengan menambahkan konfigurasi berikut di "module.config.php".

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

Secara default, lapisan Tampilan memiliki perilaku default untuk semua komponennya. Misalnya, aViewModelmenyelesaikan nama template dari tindakan pengontrol di dalam root template dengan aturan "huruf kecil-modul-nama / huruf kecil-pengendali-nama / huruf kecil-tindakan-nama". Namun, ini dapat diganti olehsetTemplate() metode ViewModel.

Pengontrol dan Lapisan Tampilan

Secara default, pengontrol tidak perlu mengirim data apa pun ke lapisan tampilan. Cukup menulis template di tempat yang tepat.

Misalnya, dalam contoh kita, TutorialController, template harus ditempatkan di myapp/module/Tutorial/view/tutorial/tutorial/index.phtml. Ituindex.phtmlmengacu pada template berbasis PHP dan akan ditampilkan oleh PHPRenderer. Ada penyaji lain sepertiJsonRenderer untuk json keluaran dan FeedRenderer untuk rss dan atom keluaran.

Daftar lengkapnya adalah sebagai berikut -

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

Template Aplikasi Zend

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

Akhirnya, kami berhasil menyelesaikan Tutorial modul dan kita dapat mengaksesnya menggunakan url - http://localhost:8080/tutorial.

Meneruskan Data ke View Layer

Cara termudah untuk mengirim data ke lapisan tampilan adalah dengan menggunakan ViewModelargumen. BerubahindexAction metode adalah sebagai berikut -

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

Sekarang, ubah index.phtml mengajukan sebagai berikut -

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

Lihat Pembantu

Sebuah View Helper digunakan untuk menulis fungsi atomik kecil untuk digunakan dalam template. Zend framework menyediakan antarmuka, Zend \ View \ Helper \ HelperInterface untuk menulis pembantu tampilan standar.

HelperInterface hanya memiliki dua metode,

  • setView() - Metode ini menerima instance / implementasi Zend \ View \ Renderer \ RendererInterface.

  • getView() - Ini digunakan untuk mengambil contoh itu.

Daftar kode lengkap HelperInterface adalah sebagai berikut -

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(); 
}

Untuk menggunakan helper dalam skrip tampilan Anda, akses menggunakan $this->helperName().

Pembantu Bawaan

Zend Framework menyediakan banyak fungsi pembantu bawaan untuk berbagai keperluan. Beberapa View Helpers tersedia dizend-mvc adalah sebagai berikut -

URL

Pembantu URL digunakan untuk menghasilkan URL yang cocok dengan rute yang ditentukan dalam aplikasi.

Definisi pembantu URL adalah -

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

Misalnya, dalam modul tutorial, rute tersebut dinamai sebagai tutorial dan memiliki dua parameter action dan id. Kita dapat menggunakan pembantu URL untuk menghasilkan dua URL yang berbeda seperti yang ditunjukkan di bawah ini -

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

Hasilnya adalah sebagai berikut -

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

Placeholder

Pembantu placeholder digunakan untuk mempertahankan konten antara skrip tampilan dan contoh tampilan. Ini memberikan opsi untuk mengatur data pada awalnya dan kemudian menggunakannya di tahap selanjutnya.

Misalnya, kita dapat mengatur, katakanlah company name dan kemudian menggunakannya di semua tempat lain.

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

Placeholder menyediakan beberapa opsi lanjutan untuk menghasilkan konten kompleks dari array dan objek PHP. Ini juga memiliki opsi untuk menangkap bagian tertentu dari templat itu sendiri.

Misalnya, kode berikut menangkap hasil template di antaranya dan menyimpannya di file productlist placeholder.

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

Pembantu Doctype digunakan untuk menghasilkan berbagai doctypes html. Ini adalah implementasi konkret dariPlaceholderpembantu. Doctype dapat diatur dalam file bootstrap dan file konfigurasi.

Penggunaan dasar ditunjukkan di bawah ini -

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

Helper HeadTitle digunakan untuk menghasilkan elemen judul html. Ini adalah implementasi konkret dariPlaceholderpembantu. Zend menyediakan opsi untuk menyetel judul dalam file konfigurasi modul dan dapat disetel di tingkat mana pun seperti situs, modul, pengontrol, tindakan, dll. Kode parsial untuk HeadTitle adalah sebagai berikut -

Module

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

Template

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

Result

action - controller - module - Zend Framework

HeadMeta

Helper HeadMeta digunakan untuk membuat tag meta html. Ini adalah implementasi konkret dari pembantu Placeholder.

Template -

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

Result

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

HeadLink

Helper HeadLink digunakan untuk membuat tautan html untuk menyertakan sumber daya eksternal. Ini adalah implementasi konkret dari pembantu Placeholder.

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

Helper HeadStyle digunakan untuk menghasilkan gaya CSS sebaris. Ini adalah implementasi konkret dari pembantu Placeholder.

Template

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

HeadScript

HeadScript digunakan untuk menghasilkan skrip sebaris atau untuk menyertakan skrip eksternal. Ini adalah implementasi konkret dari pembantu Placeholder.

Template

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

InlineScript

InlineScript digunakan untuk membuat skrip di bagian head dan body dari template html. Ini berasal dari HeadScript.

HTMLList

HTMLList digunakan untuk menghasilkan daftar berurutan dan tidak berurutan. Definisi dari HTMLList adalah sebagai berikut -

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>

Siklus

Siklus digunakan untuk menghasilkan alternatif dalam lingkungan loop. Ini memiliki fungsi assign, next dan prev.

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>

Beberapa pembantu penting lainnya adalah sebagai berikut -

  • BasePath - BasePath digunakan untuk menghasilkan jalur folder publik dari root aplikasi.

  • Partial - Partial digunakan untuk membuat template tertentu dalam lingkup variabelnya sendiri.

  • PartialLoop - PartialLoop seperti Partial, tetapi digunakan di lingkungan perulangan.

  • Identity - Identitas digunakan untuk mengambil identitas pengguna yang masuk dari Layanan Otentikasi.

  • JSON- JSON digunakan dalam lingkungan yang tenang, dengan keluaran dalam format JSON. Ini memancarkan header HTTP yang tepat dan menonaktifkan konsep tata letak.

Masih banyak pembantu yang tersedia di Zend Framework seperti i18n helper, form helpers, pagination helpers, navigation helpers, dll.

Membuat View Helpers

Zend Framework menyediakan file bawaan AbstractHelper menerapkan HelperInterface untuk menulis view helper.

Langkah-langkah dalam menulis pembantu baru adalah sebagai berikut -

  • Step 1 - Perluas kelas Zend \ View \ Helper \ AbstractHelper.

  • Step 2 - Timpa __invoke() fungsi.

  • Step 3 - Atur konfigurasi di file module.config.php file.

  • Step 4 - Gunakan view helper dalam skrip tampilan.

Sekarang mari kita buat file TestHelper

Buat folder Helper di myapp/module/Tutorial/src/View directory. MenulisTestHelper di dalam direktori Helper, TestHelper.php.

Daftar lengkapnya adalah sebagai berikut -

<?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'); 
   } 
}

Setel konfigurasi di module.config.php.

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

Gunakan yang baru dibuat TestHelper dalam about lihat skrip.

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