как создать поиск в laravel 5.8 - PullRequest
1 голос
/ 29 марта 2020

Я хочу создать поиск по названию постов "slug", а когда он искал посты, я хочу показать мне результаты в списке. Я уже создал страницу со списком авторов и категорий. Когда я нажимаю на категории, он показывает текущую категорию с сообщениями и для авторов - то же самое. Теперь я просто хочу создать поиск. При поиске чего-то, результат показывает мне сообщения со списком, как я сделал для авторов и категорий.

Примечание: у меня есть поле поиска на header.blade. php, я получил доступ к этой странице заголовка для главной страницы и загрузил эту главную страницу на list.blade. php

Это код поиска на header.blade. php page

<div class="head-search">

  <form role="form" action="/" method="get">
     <!-- Input Group -->
     <div class="input-group">
       <input type="text" name="search" class="form-control" placeholder="Type Something"> 
       <span class="input-group-btn">
         <button type="submit" class="btn btn-primary">Search</button>
       </span>
     </div>
   </form>

</div>

Это ListingPageController. php

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Post;

class ListingPageController extends Controller
{
    public function index(){
      return view('front.listing', ['posts'=>[]]);
    }
    public function listing($id){ 
      $posts = Post::with(['comments','category','creator'])->where('status',1)->where('created_by',$id)->orderBy('id','DESC')->paginate(5); 
      return view('front.listing',compact('posts')); 
    }

    public function listing1($id){ 
      $posts = Post::with(['comments','category','creator'])->where('status',1)->where('category_id',$id)->orderBy('id','DESC')->paginate(5); 
      return view('front.listing',compact('posts'));
    }

}

И это list.blade. php


@extends('front.layout.master') 
@section('content')

<section class="breadcrumb_section">
    <div class="container">
        <div class="row">
        </div>
    </div>
</section>

<div class="container">
<div class="row">
<div class="col-md-8">
    @foreach($posts as $key=>$post)
                @if($key === 0)

<div class="entity_wrapper">
    <div class="entity_title header_purple">
        <h1><a href="{{ url('/category') }}/{{ $post->category_id }}">{{ $post->category->name }}</a></h1>
    </div>
    <!-- entity_title -->

    <div class="entity_thumb">
        <img class="img-responsive" src="{{ asset('post') }}/{{ $post->main_image }} " alt="{{ $post->title }}">
    </div>
    <!-- entity_thumb -->

    <div class="entity_title">
        <a href="{{ url('/details') }}/{{ $post->slug }}" target="_blank"><h3> {{ $post->title }} </a></h3>
    </div>
    <!-- entity_title -->

    <div class="entity_meta">
         by: <a href="{{ url('/author') }}/{{ $post->creator->id }}">{{ $post->creator->name }} </a> , {{$post->created_at->diffForHumans()}}
    </div>
    <!-- entity_meta -->

    <div class="entity_content">
        {{ str_limit( $post->short_description,200,'...' )  }}
    </div>
    <!-- entity_content -->

    <div class="entity_social">

        <span><i class="fas fa-comment"></i><a href="{{ url('/details') }}/{{ $post->slug }}" target="_blank">{{ count($post->comments) }}  Comments</a></span>
    </div>
    <!-- entity_social -->

</div>
<!-- entity_wrapper -->
      @else
    @if($key === 1)
<div class="row">
    @endif <!-- first if will be ended here -->
    <div class="col-md-6" style="min-height: 555px;margin-bottom:2%"> <!-- it's for space top of page ignation-->
        <div class="category_article_body">
            <div class="top_article_img">
                <img class="img-fluid" src="{{ asset('post') }}/{{ $post->list_image }}" alt="{{ $post->title }}">
            </div>
            <!-- top_article_img -->

            <div class="category_article_title">
                <h5>
                    <a href="{{ url('/details') }}/{{ $post->slug }}" target="_blank"> {{ $post->title }} </a>
                </h5>
            </div>
            <!-- category_article_title -->

            <div class="article_date">
               by: <a href="{{ url('/author') }}/{{ $post->creator->id }}">{{ $post->creator->name }} </a> , {{$post->created_at->diffForHumans()}}
            </div>
            <!-- article_date -->

            <div class="category_article_content">
               {{ str_limit( $post->short_description,100,'...' )  }}
            </div>
            <!-- category_article_content -->

            <div class="widget_article_social">

                <span><i class="fas fa-comment"></i><a href="{{ url('/details') }}/{{ $post->slug }}" target="_blank">{{ count($post->comments) }}  Comments</a></span>
            </div>
            <!-- article_social -->

         </div>
        <!-- category_article_body -->

        </div>
    <!-- col-md-6 -->
    @if($loop->last)

    </div>
      @endif
        @endif
         @endforeach


         <div style="margin-left: 40%">
             {{ $posts->links() }}

             </div>

И это моя страница маршрута

Route::get('/', 'HomePageController@index'); 
Route::get('/category/{id}', 'ListingPageController@listing1');
Route::get('/author/{id}', 'ListingPageController@listing');
Route::get('/listing', 'ListingPageController@index');
Route::get('/details/{slug}', 'DetailsPageController@index')->name('details');

1 Ответ

1 голос
/ 30 марта 2020

Вы не указали связь между слагом и постами. Слизни в другой таблице? Это отношение один-к-одному или один-ко-многим !!!

Как я не знаю, скажем, есть отдельная таблица для слизней, и это отношение один-ко-многим из слизняк к постам То есть у одного слизняка может быть много постов. И у слаг есть поле с именем, name для текста слаг.

В вашей заданной форме это означает HomepageController@index. Или вы можете использовать отдельный контроллер и метод в качестве вашего wi sh.

Внутри метода напишите запрос, чтобы получить сообщения, в которых текст слагов совпадает в таблице слагов. как показано ниже,

public function search(Request $request){
  $posts = Post::with(['comments','category','creator'])
               ->join('slugs', 'posts.slug_id', '=', 'slugs.id')
               ->where('slugs.name', 'LIKE', '%'.$request->search. '%')
               ->where('posts.status',1)
               ->where('posts.created_by',$id)->orderBy('posts.id','DESC')->paginate(5); 

   // return to your designated page with data
}

Или, если в таблице сообщений есть столбец слагов, вы можете заменить запрос следующим образом:

$posts = Post::with(['comments','category','creator'])
              ->where('slug', 'LIKE', '%'.$request->search. '%')
              ->where('status',1)->where('created_by',$id)
              ->orderBy('id','DESC')->paginate(5); 
...