关于搜索功能的实现原理(laravel框架)
admin
2023-06-16 22:01:41
0

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


    
        
            选择分类:
            
                
                    全部
                    @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]);
}


相关内容

热门资讯

菲总统马科斯访日,菲律宾民众在... 【环球时报报道 记者 邢晓婧】菲律宾总统马科斯26日抵达日本,开启为期4天的访日行程。据菲律宾ABS...
国家安全部提示:这些码不能随便... 扫码关注,扫码支付,扫码登录……二维码已融入我们工作、生活的方方面面,为我们提供了巨大便利。然而,国...
伊比莱瑞取得不锈钢粉末自动注射... 国家知识产权局信息显示,东莞市伊比莱瑞科技有限公司取得一项名为“一种不锈钢粉末自动注射成型装置”的专...
星链涨价5倍,五角大楼和Spa... 【文/观察者网 熊超然】随着亿万富翁马斯克拥有的“星链”(Starlink)网络引导美制自杀式无人机...
人民日报刊文:妄图洗白成“解放... 妄图洗白成“解放者”,日本注定徒劳(环球走笔)牛瑞飞 《人民日报》(2026年05月27日 第 15...
AI支付时代要来了吗?支付宝A... 【大河财立方 记者 杨霄 王宇】5月26日,在支付宝AI支付生态大会上,支付宝宣布,“AI支付”已完...
毫厘间的山河:0.001%背后... 元素周期表的版图上,锌,是一块古老而平凡的疆域。但当它的纯度跃升至99.998%时,这块金属便被赋予...
朝鲜进行新型武器系统试射 当地时间5月26日,朝鲜导弹总局和国防科学院进行轻型多用途导弹发射系统和多管战术巡航导弹武器系统试验...
原创 华... 华为各大产品全面发展,而且是多系列多版本,其中手机/笔记本均拥有4个系列,平板/手表均拥有6个系列,...
俄法院裁定:立即赔偿俄约200... △俄罗斯中央银行(资料图)当地时间5月26日,俄罗斯莫斯科仲裁法院批准俄央行的申请,将对欧洲清算银行...