欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

Laravel框架搜索分页功能示例

程序员文章站 2023-11-23 17:20:10
本文实例讲述了laravel框架搜索分页功能。分享给大家供大家参考,具体如下: 控制器controller /** * 文章搜索 * * @auth...

本文实例讲述了laravel框架搜索分页功能。分享给大家供大家参考,具体如下:

控制器controller

/**
 * 文章搜索
 *
 * @author ying
 * @param void
 * @return void
 */
public function mesarticlesearch()
{
  //接值
  $input=input::get();
  //调用模型查询
  //实例化类
  $cate=new article();
  //调用自定义方法 查询分类
  $artinfo=$cate->searchall($input);
  //从session的用户名
  $username=session('user_name');
  //实例化类
  $cate=new category();
  //调用自定义方法 查询分类
  $cateinfo=$cate->selectall();
  return view('admin.article',['username'=>$username,'artinfo'=>$artinfo,'cateinfo'=>$cateinfo,'cate_id'=>$input['cate_id'],'title'=>$input['title']]);
}

模型model

/**
 * 文章搜索
 *
 * @author ying
 * @param void
 * @return void
 */
public function searchall($input)
{
  //判断
  if($input['cate_id']!=0&&$input['title']!=""){
    return $this->join('user','u_id','=','user.id')
          ->join('category','article.cate_id','=','category.cate_id')
          ->select('user_name','cate_name','article.*')
          ->where('category.status','0')
          ->where(array('category.cate_id'=>$input['cate_id']))
          ->where('title','like','%'.$input['title'].'%')
          ->orderby('article.sort','desc')
          ->paginate(3);
  }else if($input['cate_id']!=0&&$input['title']==""){
    return $this->join('user','u_id','=','user.id')
          ->join('category','article.cate_id','=','category.cate_id')
          ->select('user_name','cate_name','article.*')
          ->where('category.status','0')
          ->where(array('category.cate_id'=>$input['cate_id']))
          ->orderby('article.sort','desc')
          ->paginate(3);
  }else if ($input['cate_id']==0&&$input['title']!=""){
    return $this->join('user','u_id','=','user.id')
          ->join('category','article.cate_id','=','category.cate_id')
          ->select('user_name','cate_name','article.*')
          ->where('category.status','0')
          ->where('title','like','%'.$input['title'].'%')
          ->orderby('article.sort','desc')
          ->paginate(3);
  }else{
   return  $this->join('user','u_id','=','user.id')
          ->join('category','article.cate_id','=','category.cate_id')
          ->select('user_name','cate_name','article.*')
          ->where('category.status','0')
          ->orderby('article.sort','desc')
          ->paginate(3);
  }
}

比较low

视图view

<div class="list-page" style="margin-left: 400px">
{{$artinfo->appends(['cate_id' => $cate_id])->appends(['title' => $title])->render()}}
</div>

更多关于laravel相关内容感兴趣的读者可查看本站专题:《laravel框架入门与进阶教程》、《php优秀开发框架总结》、《php面向对象程序设计入门教程》、《php+mysql数据库操作入门教程》及《php常见数据库操作技巧汇总

希望本文所述对大家基于laravel框架的php程序设计有所帮助。