直接上我项目中的代码,后面会上简单的代码:
控制器层:
public function index(){
$data = [];//此处$data,暂时完全没用
$goods = (new GoodsB())->getLists($data,5);//调用服务层的方法
return view('',[
'goods' => $goods
]);
}
GoodsB:服务层:
//获取分页列表的数据
public function getLists($data, $num = 5){
try{
$list = $this->model->getLists($data, $num);//此处是调用模型层里面的方法。$data没用
$result = $list->toArray();
$result['render'] = $list->render();//此处进行,分页的数据处理。就直接调用这个方法即可。自行打印观察
}catch (\Exception $e){
$result = \app\common\lib\Arr::getPaginateDefaultData($num);//有错误,返回一种定义的错误格式
}
return $result;
}
model模型层:
public function getLists($data,$num = 10){
$order = ['listorder' => 'desc','id' => 'desc'];//排序条件
$list = $this->whereIn('status',[0,1]) //查找状态为0和1的
->order($order) //排序
->paginate($num); //重点,分页处理的的方法。$num为每页获取几条,这里只需要这个参数
return $list;
}
前端渲染:
效果展示:
到此,我项目中的就演示完了。
项目中的代码太复杂,看不懂?那下面就,介绍简单版本。
控制器层,直接把代码写完:
public function index(){
/*$data = [];
$goods = (new GoodsB())->getLists($data,5);
return view('',[
'goods' => $goods
]);*/
$list = \think\facade\Db::name('goods')->paginate(5); //直接调用这个方法,什么条件都不加。返回的是个对象
$goods = $list->render(); //用个数组去接收,处理后的分页数据
$list = $list->toArray(); //再转换为数组
$list['render'] = $goods; //再把处理后的分页,存到数组中
return view('',[
'goods' => $list //渲染给前端
]);
}
前端不变。然后达到了相同的效果。
至于,要怎么修改分页按钮样式。
一种就是直接在页面修改。因为分页返回的其实就是一个嵌套li的ul标签:获取到class为pagination的ul,然后巴拉巴拉的写一串的css样式。。。这种方式就跟我在用的框架处理方式是一样的。
二种,就是在分页处理的核心层,修改,返回ul的样式:
效果:有些按钮,就变成了紫色。你还可以尝试,去修改那几个“%s”,你会有新的发现的。
当然,不建议使用这种方法。非要用的话,也建议,重写那几个返回按钮的方法,然后加上自己的想要的样式,生成自己想要的li标签,然后返回。
,我自己也写过分页,没用框架。这次用的tp6(其实都一样),所以就记录一下。