Yii2框架实现带搜索的分页功能详细教程

0 下载量 129 浏览量 更新于2024-09-01 收藏 58KB PDF 举报
"这篇文章主要展示了如何在Yii2框架中实现分页和带搜索功能的示例,适合对Yii2框架感兴趣的开发者参考学习。" 在Yii2框架中,实现分页和搜索功能是常见的需求,特别是在处理大量数据时,为了提高用户体验,需要能够快速浏览和定位信息。下面将详细介绍如何在Yii2中实现这一功能。 首先,我们需要配置模型(Model)。在Yii2中,模型通常用于数据操作和业务逻辑。在这个例子中,我们涉及到三个模型:文章类别表(ArticleCate)、文章表(Article)以及一个专门用于搜索验证的模型(ArticleSearch)。 1. 文章表关联 在文章模型(Article)中,通过定义`hasOne`方法建立与文章类别的关联。这使得我们可以方便地获取每篇文章所属的类别信息。例如: ```php public function getCate() { return $this->hasOne(ArticleCate::className(), ['id' => 'cid']); } ``` 这里的`cid`是文章表中的外键,对应文章类别表的`id`字段。 2. 搜索模型 创建一个名为`ArticleSearch`的搜索模型,继承自文章模型(Article),位于`common/models/search`目录下。这个模型主要用于处理搜索参数并返回数据提供器(DataProvider)。 ```php namespace common\models\search; use Yii; use yii\base\Model; use yii\data\ActiveDataProvider; use common\models\Article; class ArticleSearch extends Article { // 其他规则... public function search($params) { $query = Article::find(); $dataProvider = new ActiveDataProvider([ 'query' => $query, ]); // 加载搜索参数并验证 if (!($this->load($params) && $this->validate())) { return $dataProvider; } // 使用加载的参数进行查询过滤 $query->andFilterWhere(['like', 'title', $this->title]) ->andFilterWhere(['like', 'desc', $this->desc]); // 返回数据提供器 return $dataProvider; } } ``` 在`search`方法中,我们从`Article`模型中获取查询对象,并创建一个`ActiveDataProvider`。接着,我们加载传入的搜索参数并验证,然后根据验证后的参数过滤查询。这里假设我们对`title`和`desc`字段进行了搜索,可以根据实际需求添加更多的搜索条件。 在视图(View)中,我们可以使用`yii\widgets\ActiveForm`创建搜索表单,然后调用`ArticleSearch`模型的`search`方法获取数据提供器,再使用`yii\widgets\Pagination`实现分页。 ```php use yii\widgets\ActiveForm; use yii\helpers\Url; use yii\widgets\LinkPager; $form = ActiveForm::begin(['action' => ['index']]); echo $form->field($searchModel, 'title'); echo $form->field($searchModel, 'desc'); echo '<div class="form-group">'; echo Html::submitButton('搜索', ['class' => 'btn btn-primary']); echo '</div>'; ActiveForm::end(); $dataProvider = $searchModel->search(Yii::$app->request->queryParams); echo LinkPager::widget([ 'pagination' => $dataProvider->pagination, ]); ``` 这样,我们就实现了在Yii2中带有搜索功能的分页。用户可以在搜索框中输入关键词,然后点击“搜索”按钮,页面将展示符合条件的文章,并且可以通过分页导航查看不同页的数据。