排序


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

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

  1. function actionIndex()
  2. {
  3. $sort = new Sort([
  4. 'attributes' => [
  5. 'age',
  6. 'name' => [
  7. 'asc' => ['first_name' => SORT_ASC, 'last_name' => SORT_ASC],
  8. 'desc' => ['first_name' => SORT_DESC, 'last_name' => SORT_DESC],
  9. 'default' => SORT_DESC,
  10. 'label' => 'Name',
  11. ],
  12. ],
  13. ]);
  14. $models = Article::find()
  15. ->where(['status' => 1])
  16. ->orderBy($sort->orders)
  17. ->all();
  18. return $this->render('index', [
  19. 'models' => $models,
  20. 'sort' => $sort,
  21. ]);
  22. }

在视图中:

  1. // 显示指向排序动作的链接
  2. echo $sort->link('name') . ' | ' . $sort->link('age');
  3. foreach ($models as $model) {
  4. // 在这里显示 $model
  5. }

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

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