как показать только один раз данные с помощью цикла foreach в laravel .... пожалуйста, код - PullRequest
0 голосов
/ 24 июня 2018

Это мой код дисплея

 @foreach($managefee as $managefees)
    @if($managefees->university==$university[0]->id)
        @if($managefees->eduId=="Undergraduate")

           @foreach($dept as $depts)
             @if($depts->id==$managefees->deptId)
                  <h4>{{$depts->name}}</h4>

                @foreach($degree as $degrees)
                    @if($degrees->id==$managefees->degreeId)
                       <li>{{$degrees->name}}</li>
                    @endif
                  @endforeach

             @endif
             @endforeach

        @endif

    @endif
@endforeach

Ожидаемый результат:

expected output picture

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

Вот моя таблица базы данных:

+----+--------+--------+----------+------------+----------+----------------------------+-----+---------------+-----+------------+
| id |  fee   | deptId | degreeId | university | hec_dept |          degreeR           | hec |     eduId     | pec | deleted_at |
+----+--------+--------+----------+------------+----------+----------------------------+-----+---------------+-----+------------+
|  1 | 250000 |      1 |        6 |          1 |        1 | lorem ipsum dolor sit      | HEC | Undergraguate | PEC | null       |
|  2 | 230000 |      1 |        7 |          1 |        1 | lorem ipsum dolor sit amet | HEC | Undergraguate | PEC | null       |
+----+--------+--------+----------+------------+----------+----------------------------+-----+---------------+-----+------------+

Вот мой запрос контроллера:

public function findUniversityDetailByCity($id) {
    $uniid = Crypt::decrypt($id);
    $heading = $uniid;
    $university = manageUniversityModel::where('id', '=', $uniid)->get();
    $city = addcity::all();
    $managefee = managefee::all();
    $degree = manageDegreeModel::all();
    $dept = uniFormDepartment::all();
    $country = addCountry::all();
    $edulevel = edulevel::all();
    return view('findUniversityDetailByCity', compact('university', 'city', 'managefee', 'degree', 'dept', 'country', 'edulevel'));
}

1 Ответ

0 голосов
/ 07 июля 2018

manageUniversityModel.php

// this is how you create relationship between university and managefee or whatever...
public function managefees() {
    return $this->hasMany(managefee::class, 'university', 'id');
}

managefee.php

public function departments() {
    return $this->hasMany(uniFormDepartment::class, 'deptId', 'id');
}

public function degrees() {
    return $this->hasMany(manageDegreeModel::class, 'degreeId', 'id');
}

Контроллер:

public function findUniversityDetailByCity($id) {
    // I don't know why would you use Crypt here?
    $uniid = Crypt::decrypt($id);
    $heading = $uniid;

    // you can use find(), this will fetch first model by id
    $university = manageUniversityModel::find($uniid);

    // instead of fetch every single row from the database, use where cluse
    // and using with() allows you to load related models. 
    $managefees = managefee::with('departments', 'degrees')
                            ->where('university', $uniid)
                            ->where('eduId', 'Undergraduate')->get();

    // You don't need to fetch them separately, let Laravel do it for you.
    // $degree = manageDegreeModel::all(); <-- this is already loaded in managefees 
    // $dept = uniFormDepartment::all();   <-- this is already loaded in managefees 


    // I would not recommend fetching every row at the same, instead use limits and pagination.
    $city = addcity::all();
    $country = addCountry::all();
    $edulevel = edulevel::all();

    return view('findUniversityDetailByCity', compact('university', 'city', 'managefees', 'country', 'edulevel'));
}

Вид:

@foreach($managefees as $managefee)
    // you don't need to check for ids manually 
    @foreach($managefee->departments as $department)
         <h4>{{ $department->name }}</h4>

         // do this only if you have same degrees in every department
         @foreach($managefee->degrees as $degree)
             <li>{{ $degree->name }}</li>
         @endforeach
    @endforeach
@endforeach

PS : научиться использовать связи с базами данных и объединения. Вы могли бы сделать структуру базы данных лучше.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...