承接 ez-php/view 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

ez-php/view

最新稳定版本:1.11.1

Composer 安装命令:

composer require ez-php/view

包简介

PHP template engine for the ez-php framework — layouts, sections, partials, and HTML escaping

README 文档

README

PHP template engine for the ez-php framework. Renders .php template files with layout inheritance, named sections, reusable partials, and HTML escaping — no external library required.

Installation

composer require ez-php/view

Quick Start

Register the provider in provider/modules.php:

use EzPhp\View\ViewServiceProvider;

$app->register(ViewServiceProvider::class);

Add config to config/view.php:

return [
    'path' => env('VIEW_PATH', base_path('resources/views')),
];

Render a template from a controller:

use EzPhp\View\View;

return new Response(View::render('home', ['name' => 'Alice']));

Template Files

Templates are plain PHP files stored in resources/views/ (or the configured path).

resources/views/
├── layouts/
│   └── app.php
├── partials/
│   └── nav.php
└── home.php

Template names use dot-notation as directory separators:

  • 'home'views/home.php
  • 'layouts.app'views/layouts/app.php
  • 'users.profile'views/users/profile.php

Template API

Inside every template file, $this refers to a TemplateContext that exposes:

$this->e(string $value): string

HTML-escape a value. Always use for user-supplied data.

<p>Hello, <?= $this->e($name) ?>!</p>

$this->extends(string $template): void

Declare that this template extends a layout.

<?php $this->extends('layouts.app') ?>

$this->section(string $name): void / $this->endSection(): void

Capture named content for the layout.

<?php $this->section('content') ?>
<h1>Hello!</h1>
<?php $this->endSection() ?>

$this->yield(string $name, string $default = ''): string

In the layout, output a named section from the child template.

<main><?= $this->yield('content') ?></main>
<title><?= $this->yield('title', 'My App') ?></title>

$this->partial(string $template, array $data = []): string

Render a sub-template and return its output.

<header><?= $this->partial('partials.nav', ['active' => 'home']) ?></header>

Layout Example

resources/views/layouts/app.php

<!DOCTYPE html>
<html>
<head>
    <title><?= $this->yield('title', 'My App') ?></title>
</head>
<body>
    <header><?= $this->partial('partials.nav') ?></header>
    <main><?= $this->yield('content') ?></main>
</body>
</html>

resources/views/home.php

<?php $this->extends('layouts.app') ?>

<?php $this->section('title') ?>Home<?php $this->endSection() ?>

<?php $this->section('content') ?>
<h1>Welcome, <?= $this->e($name) ?>!</h1>
<?php $this->endSection() ?>

Static Facade

use EzPhp\View\View;
use EzPhp\View\ViewEngine;

// In tests
View::setEngine(new ViewEngine('/tmp/views'));
View::resetEngine(); // tearDown()

// In application code (after ViewServiceProvider)
View::render('home', ['name' => 'Alice']);

Direct Engine Usage

use EzPhp\View\ViewEngine;

$engine = new ViewEngine('/path/to/views');
$html   = $engine->render('home', ['name' => 'Alice']);

统计信息

  • 总下载量: 0
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 7
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 0
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-03-22

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固