yii框架搜索后分页

控制器里这样写,Shop必须是gii生成的model。

use app\models\Shop;

use yii\data\Pagination; 

public function actionShow(){

        //$search = Yii::$app->request->get('search');
        //$bid = Yii::$app->request->get('bid');
        //$tid = Yii::$app->request->get('tid');

        //把上面的这三个变量放进去就可以根据传过来的值多条件搜索分页了

        $query = Shop::find()->where("bid in (1,3) and tid in(1,3) and sname like '%苹果%'");   //where里可以直接写成数组格式的条件也可以写成原生的拼接语句
        $countQuery = clone $query;
        $pages = new Pagination(['totalCount' => $countQuery->count(),'pagesize'=>3]);
        $models = $query->offset($pages->offset)
            ->limit($pages->limit)
            ->all();

            // var_dump($models);
        return $this->render('show',[
             'models' => $models,
             'pages' => $pages,
        ]);

    }

视图层show.php里这样写

<?php use \yii\widgets\LinkPager; ?>//一定要将小部件引到视图层
    <table>
        <?php foreach ($models as $key => $value): ?>
            <tr>
                <td><?php echo $value['bid'] ?></td>
                <td><?php echo $value['tid'] ?></td>
                <td><?php echo $value['sname'] ?></td>
            </tr>        
        <?php endforeach ?>        
    </table>
    <?php  //显示分页
    echo LinkPager::widget([
    'pagination' => $pages,
]);?>


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值