介绍 入门 应用结构 请求处理 关键概念 配合数据库工作 接收用户数据 显示数据 安全 缓存 RESTfulWeb服务 开发工具 测试 高级专题 小部件 助手类 其他

发布于 2015-08-01 11:24:06 | 264 次阅读 | 评论: 0 | 来源: 网络整理

有时显示数据会根据一个或多个属性进行排序。如果你正在使用 数据提供者数据小部件 中之一,排序 可以为你自动处理。否则,你应该创建一个 yiidataSort 实例,配置好后 将其应用到查询中。也可以传递给视图,可以在视图中通过某些属性创建链接来排序。

如下是一个典型的使用范例,

function actionIndex()
{
    $sort = new Sort([
        'attributes' => [
            'age',
            'name' => [
                'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
                'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
                'default' => SORT_DESC,
                'label' => 'Name',
            ],
        ],
    ]);

    $models = Article::find()
        ->where(['status' => 1])
        ->orderBy($sort->orders)
        ->all();

    return $this->render('index', [
         'models' => $models,
         'sort' => $sort,
    ]);
}

在视图中:

// 显示指向排序动作的链接
echo $sort->link('name') . ' | ' . $sort->link('age');

foreach ($models as $model) {
    // 在这里显示 $model
}

以上,我们声明了支持了两个属性的排序:nameage。 我们通过排序信息来查询以便于查询结果通过 Sort 对象 排序后更加准确有序。在视图中,我们通过相应的属性 展示了链接到页的两个超链接和数据排序。

yiidataSort 类将获得自动传递的请求参数 并相应地调整排序选项。 你可以通过配置 yiidataSort::$params 属性来调整参数。

最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务