zoukankan      html  css  js  c++  java
  • yii小部件

    小部件是在视图中使用的可重用单元, 使用面向对象方式创建复杂和可配置用户界面单元。 例如,日期选择器小部件可生成一个精致的允许用户选择日期的日期选择器, 你只需要在视图中插入如下代码:

    <?php
    use yiijuiDatePicker;
    ?>
    <?= DatePicker::widget(['name' => 'date']) ?>
    

      

    Yii提供许多优秀的小部件,比如 active formmenu, jQuery UI widgets, Twitter Bootstrap widgets。 接下来介绍小部件的基本知识,如果你想了解某个小部件请参考对应的类 API 文档。

    使用小部件

    小部件基本上在 views 中使用, 在视图中可调用 yiiaseWidget::widget() 方法使用小部件。 该方法使用 配置 数组初始化小部件并返回小部件渲染后的结果。 例如如下代码插入一个日期选择器小部件,它配置为使用俄罗斯语, 输入框内容为 $model 的 from_date 属性值。

    <?php
    use yiijuiDatePicker;
    ?>
    <?= DatePicker::widget([
        'model' => $model,
        'attribute' => 'from_date',
        'language' => 'ru',
        'dateFormat' => 'php:Y-m-d',
    ]) ?>
    

      

    一些小部件可在 yiiaseWidget::begin() 和 yiiaseWidget::end() 调用中使用数据内容。 例如如下代码使用 yiiwidgetsActiveForm 小部件生成一个登录表单, 小部件会在 begin() 和 end() 执行处分别生成 <form> 的开始标签和结束标签, 中间的任何代码也会被渲染。

    <?php
    use yiiwidgetsActiveForm;
    use yiihelpersHtml;
    ?>
    
    <?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(); ?>
    

      

    注意和调用 yiiaseWidget::widget() 返回渲染结果不同, 调用 yiiaseWidget::begin() 方法返回一个可组建小部件内容的小部件实例。

    注意: 当调用 yiiaseWidget::end() 的时候,一些小部件将使用 输出缓冲 来调整封闭的内容。因此,当调用 yiiaseWidget::begin() 和 yiiaseWidget::end() 时,最好在同一个视图文件里。 不遵循这个规则可能会导致意外的输出。

    配置全局默认值

    小部件的全局默认值可以通过 DI 容器配置:

    Yii::$container->set('yiiwidgetsLinkPager', ['maxButtonCount' => 5]);
    

    有关详细信息,请参阅 依赖注入容器“实践中的应用”一节 。

    创建小部件

    可以根据需要以两种不同方式创建小部件。

    1: 使用 widget() 方法

    继承 yiiaseWidget 类并覆盖 yiiaseWidget::init() 和/或 yiiaseWidget::run() 方法可创建小部件。通常 init() 方法处理小部件属性, run() 方法包含小部件生成渲染结果的代码。 渲染结果可以直接“输出”或通过 run() 方法作为字符串返回。

    如下代码中 HelloWidget 编码并显示赋给 message 属性的值, 如果属性没有被赋值,默认会显示 "Hello World"。

    namespace appcomponents;
    
    use yiiaseWidget;
    use yiihelpersHtml;
    
    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 appcomponentsHelloWidget;
    ?>
    <?= HelloWidget::widget(['message' => 'Good morning']) ?>
    

      

    有时小部件需要渲染很多内容,虽然你可以在 run() 方法中嵌入内容,但更好的方法是将内容放入一个视图文件, 然后调用 yiiaseWidget::render() 方法渲染该视图文件, 例如:

    public function run()
    {
        return $this->render('hello');
    }
    

      

    2: 使用 begin() 和 end() 方法

    这类似于上面的有细微差别。 以下是另一种可在 begin() 和 end() 调用中使用的 HelloWidget, HTML 编码内容然后显示。

    namespace appcomponents;
    
    use yiiaseWidget;
    use yiihelpersHtml;
    
    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() 处理和返回。

    信息: 当你调用 yiiaseWidget::begin() 时会创建一个新的小部件 实例并在构造结束时调用 init() 方法, 在 end() 时会调用 run() 方法并输出返回结果。

    如下代码显示如何使用这种 HelloWidget

    <?php
    use appcomponentsHelloWidget;
    ?>
    <?php HelloWidget::begin(); ?>
    
        sample content that may contain one or more <strong>HTML</strong> <pre>tags</pre>
    
        If this content grows too big, use sub views
    
        For e.g.
    
        <?php echo $this->render('viewfile'); // Note: here render() method is of class yiiaseView as this part of code is within view file and not in Widget class file ?>
    
    <?php HelloWidget::end(); ?>
    

      

    默认情况下,小部件的视图应存储在 WidgetPath/views 目录,WidgetPath 代表小部件类文件所在的目录。 假如小部件类文件在 @app/components 下, 上述示例会渲染 @app/components/views/hello.php 视图文件。 您可以覆盖 yiiaseWidget::getViewPath() 方法自定义视图文件所在路径。

    最佳实践

    小部件是面向对象方式来重用视图代码。

    创建小部件时仍需要遵循MVC模式,通常逻辑代码在小部件类, 展示内容在视图中。

    小部件设计时应是独立的,也就是说使用一个小部件时候, 可以直接丢弃它而不需要额外的处理。 但是当小部件需要外部资源如 CSS,JavaScript,图片等会比较棘手, 幸运的时候Yii提供 资源包 来解决这个问题。

    当一个小部件只包含视图代码,它和视图很相似, 实际上,在这种情况下,唯一的区别是小部件是可以重用类, 视图只是应用中使用的普通 PHP 脚本。

  • 相关阅读:
    条形码工具类
    带SSL证书的httpclient 远程接口工具类
    微信后台服务器配置 、第三方后台 验证服务器地址的有效性,判断请求来自微信服务器
    java获取当前文件路径 [转]
    python django model filter 条件过滤,及多表连接查询、反向查询,某字段的distinct[转]
    HTTP响应代码集合
    JSON类库Jackson与JSON-lib性能对比[转]
    JSR规范整理
    Oracle 查看执行计划
    java中最常用jar包的用途
  • 原文地址:https://www.cnblogs.com/wntd/p/10435110.html
Copyright © 2011-2022 走看看