백엔드 개발 PHP 튜토리얼 Laravel은 수동으로 배열 페이지 매김을 생성합니다.

Laravel은 수동으로 배열 페이지 매김을 생성합니다.

Jun 08, 2018 am 09:11 AM
laravel 배열 페이징

이 글에서는 Laravel에서 Array Paging을 수동으로 생성하기 위한 구현 코드를 주로 소개합니다. 편집자는 꽤 좋다고 생각하므로 지금 공유하고 참고용으로 제공하겠습니다.

이 기사에서는 laravel이 수동으로 배열 페이징을 생성하는 구현 코드를 소개하고 이를 모든 사람과 공유합니다. 자세한 내용은 다음과 같습니다.

laravel 페이징 기능:

데이터를 페이징하는 방법에는 여러 가지가 있습니다. 가장 간단한 방법은 Query Builder 또는 Eloquent Query에서 paginate 또는 simplePaginate 메소드를 사용하는 것입니다.

paginate는 다음과 같이 사용됩니다.

//控制器中
$users = DB::table('users')->paginate(15);
return view('user.index', ['users' => $users]);

//视图中
{{ $users->links() }}
로그인 후 복사

효과는 다음과 같습니다.

"이전 페이지" "1" "2" "3" "다음 페이지"

simplePaginate는 다음과 같이 사용됩니다.

//控制器中
$users = User::where('votes', '>', 100)->simplePaginate(15);
return view('user.index', compact('users'));

//视图中
{{ $users->links() }}
로그인 후 복사

효과는 다음과 같습니다:

"이전 페이지" "다음 페이지"

참고:

  1. 간단한 "다음 페이지" 및 "이전 페이지"만 표시하려는 경우 페이지네이션 뷰 링크, 즉 각 페이지 번호를 표시할 필요가 없는 링크인 경우, 보다 효율적인 쿼리를 수행하기 위해 simplePaginate 메소드를 사용하는 것이 좋습니다.

  2. 현재 Laravel은 groupBy 문을 사용하여 페이징 작업을 효율적으로 수행할 수 없습니다. 페이지가 매겨진 결과 집합에서 groupBy를 사용해야 하는 경우 데이터베이스를 쿼리하고 페이지 매기기를 수동으로 생성하는 것이 좋습니다.

때때로 $dataA와 $dataB가 데이터베이스에서 가져온 두 개의 서로 다른 데이터 세트인 경우 $dataA와 $dataB를 동시에 뷰에 할당하고 페이지에 표시해야 합니다. 이런 상황 어떻게 해야 할까요?

이 경우에는 laravel 배열 페이징을 사용할 수 있습니다.

사실 laravel 문서에는 이미 paging 클래스를 사용하여 페이지를 매기는 방법이 직접 적혀 있지만 자세한 설명은 없습니다.

수동으로 페이지 매김 생성

페이지 매김 인스턴스를 수동으로 생성하고 최종적으로 배열 유형 결과를 얻으려면 필요에 따라 IlluminatePaginationPaginator 또는 IlluminatePaginationLengthAwarePaginator 인스턴스를 생성할 수 있습니다.

자세한 내용은 IlluminatePaginationLengthAwarePaginator에서 이 코드를 볼 수 있습니다.

public function __construct($items, $total, $perPage, $currentPage = null, array $options = [])
 {
  foreach ($options as $key => $value) {
   $this->{$key} = $value;
  }

  $this->total = $total;
  $this->perPage = $perPage;
  $this->lastPage = max((int) ceil($total / $perPage), 1);
  $this->path = $this->path !== '/' ? rtrim($this->path, '/') : $this->path;
  $this->currentPage = $this->setCurrentPage($currentPage, $this->pageName);
  $this->items = $items instanceof Collection ? $items : Collection::make($items);
 }
로그인 후 복사

다음은 구체적인 구현 코드입니다.

//控制器中
public function index(LiveService $liveService, Request $request)
 {
  //数据A
  $dataA = User::where('status', 1)->get()->toArray();
  //数据B
  $dataB = User::where('status', 2)->get()->toArray();
  $data = array_merge($dataA, $dataB);
  //当前页数 默认1
  $page = $request->page ?: 1;
  //每页的条数
  $perPage = 4;
  //计算每页分页的初始位置
  $offset = ($page * $perPage) - $perPage;
   //实例化LengthAwarePaginator类,并传入对应的参数
  $data = new LengthAwarePaginator(array_slice($data, $offset, $perPage, true), count($data), $perPage,
   $page, ['path' => $request->url(), 'query' => $request->query()]);
  return view('admin.users.index', compact('data'));
 }

//视图中
{{ $data->links() }}
로그인 후 복사

위는 기본적으로 컨트롤러가 배열 페이징을 획득하는 것입니다. , LengthAwarePaginator 클래스를 인스턴스화하고 필요한 매개변수를 전달한 후 array_slice() 메서드를 사용하여 각 페이지의 항목 수에 따라 각 페이지에 표시할 데이터를 가져옵니다.

위 내용은 이 글의 전체 내용입니다. 모든 분들의 학습에 도움이 되었으면 좋겠습니다. 더 많은 관련 내용은 PHP 중국어 홈페이지를 주목해주세요!

관련 권장 사항:

Laravel 프로그램 아키텍처 디자인의 액션 클래스 사용

위 내용은 Laravel은 수동으로 배열 페이지 매김을 생성합니다.의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.

핫 AI 도구

Undresser.AI Undress

Undresser.AI Undress

사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover

AI Clothes Remover

사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool

Undress AI Tool

무료로 이미지를 벗다

Clothoff.io

Clothoff.io

AI 옷 제거제

AI Hentai Generator

AI Hentai Generator

AI Hentai를 무료로 생성하십시오.

뜨거운 도구

메모장++7.3.1

메모장++7.3.1

사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전

SublimeText3 중국어 버전

중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기

스튜디오 13.0.1 보내기

강력한 PHP 통합 개발 환경

드림위버 CS6

드림위버 CS6

시각적 웹 개발 도구

SublimeText3 Mac 버전

SublimeText3 Mac 버전

신 수준의 코드 편집 소프트웨어(SublimeText3)

Laravel - 장인 명령 Laravel - 장인 명령 Aug 27, 2024 am 10:51 AM

Laravel - Artisan Commands - Laravel 5.7은 새로운 명령을 처리하고 테스트하는 새로운 방법을 제공합니다. 여기에는 장인 명령을 테스트하는 새로운 기능이 포함되어 있으며 데모는 아래에 언급되어 있습니다.

Laravel - 페이지 매김 사용자 정의 Laravel - 페이지 매김 사용자 정의 Aug 27, 2024 am 10:51 AM

Laravel - 페이지 매김 사용자 정의 - Laravel에는 사용자나 개발자가 페이지 매김 기능을 포함하는 데 도움이 되는 페이지 매김 기능이 포함되어 있습니다. Laravel 페이지네이터는 쿼리 빌더 및 Eloquent ORM과 통합되어 있습니다. 자동 페이지 매김 방법

Laravel에서 이메일 전송이 실패 할 때 반환 코드를 얻는 방법은 무엇입니까? Laravel에서 이메일 전송이 실패 할 때 반환 코드를 얻는 방법은 무엇입니까? Apr 01, 2025 pm 02:45 PM

Laravel 이메일 전송이 실패 할 때 반환 코드를 얻는 방법. Laravel을 사용하여 응용 프로그램을 개발할 때 종종 확인 코드를 보내야하는 상황이 발생합니다. 그리고 실제로 ...

laravel 일정 작업이 실행되지 않습니다 : 스케줄 후 작업이 실행되지 않으면 어떻게해야합니까? laravel 일정 작업이 실행되지 않습니다 : 스케줄 후 작업이 실행되지 않으면 어떻게해야합니까? Mar 31, 2025 pm 11:24 PM

laravel 일정 작업 실행 비 응답 문제 해결 Laravel의 일정 작업 일정을 사용할 때 많은 개발자 가이 문제에 직면합니다 : 스케줄 : 실행 ...

Laravel에서는 이메일로 확인 코드를 보내지 못하는 상황을 처리하는 방법은 무엇입니까? Laravel에서는 이메일로 확인 코드를 보내지 못하는 상황을 처리하는 방법은 무엇입니까? Mar 31, 2025 pm 11:48 PM

Laravel의 이메일을 처리하지 않는 방법은 LaRavel을 사용하는 것입니다.

DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? DCAT 관리자에서 데이터를 추가하기 위해 클릭하는 사용자 정의 테이블 기능을 구현하는 방법은 무엇입니까? Apr 01, 2025 am 07:09 AM

DCAT를 사용할 때 DCATADMIN (LARAVEL-ADMIN)에서 데이터를 추가하려면 사용자 정의의 테이블 기능을 구현하는 방법 ...

Laravel - 덤프 서버 Laravel - 덤프 서버 Aug 27, 2024 am 10:51 AM

Laravel - 덤프 서버 - Laravel 덤프 서버는 Laravel 5.7 버전과 함께 제공됩니다. 이전 버전에는 덤프 서버가 포함되어 있지 않습니다. 덤프 서버는 laravel/laravel 작곡가 파일의 개발 종속성이 됩니다.

Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Laravel Redis Connection 공유 : 선택 메소드가 다른 연결에 영향을 미치는 이유는 무엇입니까? Apr 01, 2025 am 07:45 AM

Laravel 프레임 워크 및 Laravel 프레임 워크 및 Redis를 사용할 때 Redis 연결을 공유하는 데 영향을 줄 수 있습니다. 개발자는 문제가 발생할 수 있습니다. 구성을 통해 ...

See all articles