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() ?>