关于搜索功能的实现原理(laravel框架)

这里的搜索功能主要基于表单get提交实现的

创新互联建站主要为客户提供服务项目涵盖了网页视觉设计、VI标志设计、营销型网站建设、网站程序开发、HTML5响应式成都网站建设成都做手机网站、微商城、网站托管及成都网站维护、WEB系统开发、域名注册、国内外服务器租用、视频、平面设计、SEO优化排名。设计、前端、后端三个建站步骤的完善服务体系。一人跟踪测试的建站服务标准。已经为成都展览展示行业客户提供了网站开发服务。


    
        
            选择分类:
            
                
                    全部
                    @foreach($category as $c)
                        id}}">{{$c->class_name}}
                    @endforeach
                
            
            文章标题:
            
            
            
        
    

php部分逻辑

public function article_list(){
   //echo 'zoule';exit;  测试表单是否走进方法中 大家随意写
   $shownum = 1;
   if(array_key_exists('class',$_GET)||array_key_exists('keywords',$_GET)){
      //echo '111';  
      if($_GET['class']){
      //Article模型 leftJoin表连接 查询根据俩个表里的这些字段来执行
         $postdata = Article::leftJoin('category', function($join) {
            $join->on('article.class_id', '=', 'category.id');
         })->select(['article.id','category.class_name','article.status','article.title_editing','article.update_time'])->where('article.class_id','=',$_GET['class'])->orderBy('release_time','desc')->paginate($shownum);
      }elseif($_GET['keywords']){
         $postdata = Article::leftJoin('category', function($join) {
            $join->on('article.class_id', '=', 'category.id');
         })->select(['article.id','category.class_name','article.status','article.title_editing','article.update_time'])->where('article.title_editing','=',$_GET['keywords'])->orderBy('release_time','desc')->paginate($shownum);
      
      }else{
         $postdata = Article::leftJoin('category', function($join) {
            $join->on('article.class_id', '=', 'category.id');
         })->select(['article.id','category.class_name','article.status','article.title_editing','article.update_time'])->orderBy('release_time','desc')->paginate($shownum);
      }
   }else{
      //echo '2222';
      $postdata = Article::leftJoin('category', function($join) {
         $join->on('article.class_id', '=', 'category.id');
      })->select(['article.id','category.class_name','article.status','article.title_editing','article.update_time'])->orderBy('release_time','desc')->paginate($shownum);
   }
   //分类id不是父id
   $category = DB::table('category')->where('parent_id','!=','0')->get();
   //渲染页面 传递 参数
   return view('backend.article_list',['postdata'=>$postdata,'shownum'=>$shownum,'category'=>$category]);
}

本文标题:关于搜索功能的实现原理(laravel框架)
分享URL:http://scyanting.com/article/gdpgcc.html