Yii框架小部件(Widgets)用法实例详解
本文实例讲述了Yii框架小部件(Widgets)用法。分享给大家供大家参考,具体如下
小部件
小部件是在 中使用的可重用单元, 使用面向对象方式创建复杂和可配置用户界面单元。 例如,日期选择器小部件可生成一个精致的允许用户选择日期的日期选择器, 你只需要在视图中插入如下代码
<?php use yii\jui\DatePicker; ?> <?= DatePicker::widget(['name' => 'date']) ?>
Yii提供许多优秀的小部件,比如, , , 。 接下来介绍小部件的基本知识,如果你想了解某个小部件请参考对应的类API文档。
使用小部件
小部件基本上在中使用, 在视图中可调用 方法使用小部件。 该方法使用 数组初始化小部件并返回小部件渲染后的结果。 例如如下代码插入一个日期选择器小部件,它配置为使用俄罗斯语, 输入框内容为$model
的from_date
属性值。
<?php use yii\jui\DatePicker; ?> <?= DatePicker::widget([ 'model' => $model, 'attribute' => 'from_date', 'language' => 'ru', 'dateFormat' => 'php:Y-m-d', ]) ?>
一些小部件可在 和 调用中使用数据内容。 例如如下代码使用小部件生成一个登录表单, 小部件会在begin()
和0 end()
执行处分别生成<form>
的开始标签和结束标签, 中间的任何代码也会被渲染。
<?php use yii\widgets\ActiveForm; use yii\helpers\Html; ?> <?php $form = ActiveForm::begin(['id' => 'login-form']); ?> <?= $form->field($model, 'username') ?> <?= $form->field($model, 'password')->passwordInput() ?> <div class="form-group"> <?= Html::submitButton('Login') ?> </div> <?php ActiveForm::end(); ?>
注意和调用 返回渲染结果不同, 调用 方法返回一个可组建小部件内容的小部件实例。
注意 当调用 的时候,一些小部件将使用 来调整封闭的内容。,当调用 和 时,最好在同一个视图文件里。 不遵循这个规则可能会导致意外的输出。
配置全局默认值
小部件的全局默认值可以通过 DI 容器配置:
\Yii::$container->set('yii\widgets\LinkPager', ['maxButtonCount' => 5]);
详见 。
创建小部件
继承 类并覆盖 和/或 方法可创建小部件。通常init()
方法处理小部件属性, run()
方法包含小部件生成渲染结果的代码。 渲染结果可在run()
方法中直接"echoed"输出或以字符串返回。
如下代码中HelloWidget
编码并显示赋给message
属性的值, 如果属性没有被赋值,默认会显示"Hello World"。
namespace app\ponents; use yii\base\Widget; use yii\helpers\Html; class HelloWidget extends Widget { public $message; public function init() { parent::init(); if ($this->message === null) { $this->message = 'Hello World'; } } public function run() { return Html::encode($this->message); } }
使用这个小部件只需在视图中简单使用如下代码:
<?php use app\ponents\HelloWidget; ?> <?= HelloWidget::widget(['message' => 'Good morning']) ?>
以下是另一种可在begin()
和 end()
调用中使用的HelloWidget
, HTML编码内容然后显示。
namespace app\ponents; use yii\base\Widget; use yii\helpers\Html; class HelloWidget extends Widget { public function init() { parent::init(); ob_start(); } public function run() { $content = ob_get_clean(); return Html::encode($content); } }
如上所示,PHP输出缓冲在init()
启动,所有在init()
和 run()
方法之间的输出内容都会被获取,并在run()
处理和返回。
信息 当你调用 时会创建一个新的小部件 实例并在构造结束时调用
init()
方法, 在end()
时会调用run()
方法并输出返回结果。
如下代码显示如何使用这种 HelloWidget
:
<?php use app\ponents\HelloWidget; ?> <?php HelloWidget::begin(); ?> content that may contain <tag>'s <?php HelloWidget::end(); ?>
有时小部件需要渲染很多内容,一种更好的办法是将内容放入一个文件, 然后调用方法渲染该视图文件, 例如
public function run() { return $this->render('hello'); }
小部件的视图文件默认存储在WidgetPath/views
目录,WidgetPath
代表小部件类文件所在的目录。 假如上述示例小部件类文件在@app/ponents
下, 会渲染@app/ponents/views/hello.php
视图文件。 You may override 可以覆盖方法自定义视图文件所在路径。
最佳实践
小部件是面向对象方式来重用视图代码。
创建小部件时仍需要遵循MVC模式,通常逻辑代码在小部件类, 展示内容在中。
小部件设计时应是独立的,也就是说使用一个小部件时候, 可以直接丢弃它而不需要额外的处理。 当小部件需要外部资源如CSS, JavaScript, 图片等会比较棘手, 幸运的时候Yii提供 来解决这个问题。
当一个小部件只包含视图代码,它和很相似, 实际上,在这种情况下,唯一的区别是小部件是可以重用类, 视图只是应用中使用的普通PHP脚本。
更多关于Yii相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》、《》、《》及《》
希望本文所述对大家基于Yii框架的PHP程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程