Rumah rangka kerja php Laravel Bagaimana untuk melaksanakan fungsi paging menggunakan Laravel

Bagaimana untuk melaksanakan fungsi paging menggunakan Laravel

Apr 19, 2023 am 10:09 AM

Laravel ialah rangka kerja pembangunan PHP popular yang menyediakan banyak ciri moden dan alatan mesra pembangunan, membolehkan pembangun membina tapak web dan aplikasi dengan lebih cekap. Dalam proses membangunkan aplikasi web, selalunya perlu untuk memaparkan hasil pertanyaan dalam halaman Artikel ini akan memperkenalkan cara menggunakan Laravel untuk melaksanakan fungsi paging.

1. Pengenalan kepada paging

Paging merujuk kepada kaedah membahagikan sejumlah besar data kepada beberapa halaman untuk paparan Biasanya, kami akan menetapkan bilangan keping data untuk dipaparkan pada setiap halaman dan jumlah data Apabila nilai ini melebihi, halaman akan bertukar secara automatik. Pendekatan ini boleh mengurangkan masa memuatkan halaman dan penggunaan lebar jalur, menjadikannya lebih mudah untuk pengguna melihat dan menavigasi data.

2. Operasi paging Laravel

Laravel menyediakan kelas Paginator untuk melaksanakan fungsi paging. Kita boleh mendapatkan contoh kelui dengan menghantar objek hasil pertanyaan kepada kaedah membuat Peminator dan menentukan jumlah data yang akan dipaparkan pada setiap halaman. Panggil kaedah render pada contoh, dan Laravel boleh menjana pautan penomboran secara automatik.

Mari kita lihat pelaksanaan kod khusus.

  1. Pasang Laravel

Jalankan arahan berikut untuk memasang Laravel:

composer create-project --prefer-dist laravel/laravel blog
Salin selepas log masuk
  1. Buat jadual pangkalan data Mysql

Buat artikel jadual pangkalan data dan masukkan beberapa sampel data:

CREATE TABLE `articles` (
  `id` int(10) unsigned NOT NULL AUTO_INCREMENT,
  `title` varchar(255) COLLATE utf8mb4_unicode_ci NOT NULL,
  `body` text COLLATE utf8mb4_unicode_ci NOT NULL,
  `created_at` timestamp NULL DEFAULT NULL,
  `updated_at` timestamp NULL DEFAULT NULL,
  PRIMARY KEY (`id`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_unicode_ci;
Salin selepas log masuk
INSERT INTO `articles` (`title`, `body`, `created_at`, `updated_at`) VALUES ('Article 1', 'This is article 1 content', '2021-01-01 12:00:00', '2021-01-01 12:00:00');
INSERT INTO `articles` (`title`, `body`, `created_at`, `updated_at`) VALUES ('Article 2', 'This is article 2 content', '2021-01-02 12:00:00', '2021-01-02 12:00:00');
INSERT INTO `articles` (`title`, `body`, `created_at`, `updated_at`) VALUES ('Article 3', 'This is article 3 content', '2021-01-03 12:00:00', '2021-01-03 12:00:00');
INSERT INTO `articles` (`title`, `body`, `created_at`, `updated_at`) VALUES ('Article 4', 'This is article 4 content', '2021-01-04 12:00:00', '2021-01-04 12:00:00');
Salin selepas log masuk
  1. Tentukan model Artikel

Buat fail Article.php dalam direktori app/Models , dan tambahkan kod berikut:

<?php

namespace App\Models;

use Illuminate\Database\Eloquent\Factories\HasFactory;
use Illuminate\Database\Eloquent\Model;

class Article extends Model
{
    use HasFactory;

    protected $fillable = [&#39;title&#39;, &#39;body&#39;];

    public function getDateAttribute()
    {
        return $this->created_at->format('Y-m-d');
    }
}
Salin selepas log masuk
  1. Define ArticlesController

Buat fail ArticlesController.php dalam direktori app/Http/Controllers dan tambah kod berikut:

<?php

namespace App\Http\Controllers;

use Illuminate\Http\Request;
use App\Models\Article;

class ArticlesController extends Controller
{
    public function index(Request $request)
    {
        $articles = Article::paginate(2);
        
        return view(&#39;articles.index&#39;, compact(&#39;articles&#39;));
    }
}
Salin selepas log masuk
  1. Buat paparan Artikel

Buat direktori artikel dalam direktori sumber/pandangan, cipta fail index.blade.php dalam direktori ini , dan tambah kod berikut:

@extends(&#39;layouts.app&#39;)
@section(&#39;content&#39;)
    <div class="container">
        <div class="row">
            <div class="col-md-8">
                @foreach($articles as $article)
                    <div class="card mb-3">
                        <div class="card-header">
                            {{ $article->title }}
                        </div>
                        <div class="card-body">
                            <p class="card-text">{{ $article->body }}</p>
                        </div>
                        <div class="card-footer text-right">
                            <small class="text-muted">{{ $article->date }}</small>
                        </div>
                    </div>
                @endforeach
                {{ $articles->links() }}
            </div>
        </div>
    </div>
@endsection
Salin selepas log masuk

Analisis:

  • Mula-mula, kami memaparkan setiap artikel dalam gelung foreach.
  • Gunakan atribut $article->title dan $article->body untuk mendapatkan tajuk dan kandungan artikel daripada model Artikel.
  • Dapatkan tarikh penerbitan artikel dalam atribut $article->date.
  • Panggil kaedah $articles->links() dan Laravel akan menjana pautan penomboran secara automatik untuk kami.
  1. Tentukan gaya halaman

Buat fail app.css dalam direktori awam/css dan tambah kod berikut:

.card {
    margin-bottom: 20px;
}
.pagination {
    margin-top: 20px;
}
Salin selepas log masuk

Dalam fail app.blade.php dalam direktori resources/views/layouts, tambahkan kod berikut:

<!doctype html>
<html lang="{{ str_replace(&#39;_&#39;, &#39;-&#39;, app()->getLocale()) }}">
<head>
    <!-- Meta Tags -->
    <meta charset="utf-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>{{ config('app.name') }}</title>
    <!-- Styles -->
    <link href="{{ asset(&#39;css/app.css&#39;) }}" rel="stylesheet">
</head>
<body>
    <nav class="navbar navbar-expand-md navbar-light bg-white shadow-sm">
        <div class="container">
            <a class="navbar-brand" href="{{ url(&#39;/&#39;) }}">
                {{ config('app.name') }}
            </a>
            <button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="{{ __(&#39;Toggle navigation&#39;) }}">
                <span class="navbar-toggler-icon"></span>
            </button>
            <div class="collapse navbar-collapse" id="navbarSupportedContent">
                <ul class="navbar-nav mr-auto"></ul>
                <ul class="navbar-nav ml-auto"></ul>
            </div>
        </div>
    </nav>
    @yield('content')
    <script src="{{ asset(&#39;js/app.js&#39;) }}"></script>
</body>
</html>
Salin selepas log masuk

Analisis:

  • Ditambah dalam app.blade.php Gaya CSS untuk Bootstrap 4.
  • Kami juga memperkenalkan fail JS Bootstrap 4, tetapi kami tidak perlu memperkenalkannya secara manual kerana Laravel disertakan dengan alat pembungkusan Webpack, yang boleh membungkus fail JS yang diperlukan secara automatik ke dalam public/js/app . fail js.
  1. Uji fungsi paging

Lawati http://127.0.0.1:8000/articles dan anda boleh melihat bahawa senarai artikel kami telah dipaparkan, dan kami Anda boleh bertukar antara berbilang halaman melalui pautan paging.

Apa yang perlu diperhatikan di sini ialah apabila kita memanggil kaedah penomboran dalam pengawal, parameter 2 yang dihantar mewakili bilangan keping data yang akan dipaparkan pada halaman Jika nilai ini ditetapkan terlalu kecil , akan Terdapat banyak pautan paging, menyebabkan kekeliruan halaman jika nilai ini ditetapkan terlalu besar, jumlah data yang dipaparkan pada halaman akan menjadi sangat besar, menyekat permintaan untuk masa yang lama, menjejaskan kelajuan pembukaan halaman; , dan juga menyebabkan masalah seperti limpahan memori, jadi ia harus berdasarkan keadaan sebenar Situasi ditetapkan dengan teliti.

3. Ringkasan

Laravel menyediakan kelas Paginator yang berkuasa untuk melaksanakan fungsi paging, yang boleh dilaksanakan dengan mudah dengan kurang kod. Artikel ini memperkenalkan cara menggunakan Paginator untuk memaparkan data dalam pangkalan data MySQL dalam halaman. Kami juga menunjukkan cara menggunakan sifat model dalam hasil penomboran. Apabila kita perlu memaparkan sejumlah besar data semasa membangunkan tapak web dan aplikasi, paging adalah ciri penting Ia bukan sahaja dapat meningkatkan pengalaman pengguna dengan berkesan, tetapi juga mengurangkan overhed pelayan dengan berkesan.

Atas ialah kandungan terperinci Bagaimana untuk melaksanakan fungsi paging menggunakan Laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang lalu By 尊渡假赌尊渡假赌尊渡假赌

Alat panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Bagaimana membina API RESTful dengan ciri -ciri canggih di Laravel? Bagaimana membina API RESTful dengan ciri -ciri canggih di Laravel? Mar 11, 2025 pm 04:13 PM

Artikel ini membimbing membina API Restful Laravel yang mantap. Ia meliputi persediaan projek, pengurusan sumber, interaksi pangkalan data, siri, pengesahan, kebenaran, ujian, dan amalan terbaik keselamatan penting. Menangani Chall Scalability

Bagaimana untuk melaksanakan pengesahan dan kebenaran OAuth2 di Laravel? Bagaimana untuk melaksanakan pengesahan dan kebenaran OAuth2 di Laravel? Mar 12, 2025 pm 05:56 PM

Butiran artikel ini melaksanakan pengesahan dan kebenaran OAuth 2.0 di Laravel. Ia meliputi menggunakan pakej seperti penyelesaian liga/oauth2-server atau penyedia khusus, menekankan persediaan pangkalan data, pendaftaran klien, konfigurasi pelayan kebenaran

Bagaimana saya menggunakan komponen Laravel untuk mencipta elemen UI yang boleh diguna semula? Bagaimana saya menggunakan komponen Laravel untuk mencipta elemen UI yang boleh diguna semula? Mar 17, 2025 pm 02:47 PM

Artikel ini membincangkan membuat dan menyesuaikan elemen UI yang boleh diguna semula di Laravel menggunakan komponen, menawarkan amalan terbaik untuk organisasi dan mencadangkan peningkatan pakej.

Bagaimana saya membuat dan menggunakan arahan pisau tersuai di laravel? Bagaimana saya membuat dan menggunakan arahan pisau tersuai di laravel? Mar 17, 2025 pm 02:50 PM

Artikel ini membincangkan membuat dan menggunakan arahan pisau tersuai di Laravel untuk meningkatkan templat. Ia meliputi arahan yang menentukan, menggunakannya dalam templat, dan menguruskannya dalam projek besar, menonjolkan manfaat seperti kebolehgunaan semula kod yang lebih baik dan r yang lebih baik dan r

Apakah amalan terbaik untuk menggunakan Laravel dalam persekitaran awan asli? Apakah amalan terbaik untuk menggunakan Laravel dalam persekitaran awan asli? Mar 14, 2025 pm 01:44 PM

Artikel ini membincangkan amalan terbaik untuk menggunakan Laravel dalam persekitaran awan-asli, yang memberi tumpuan kepada skalabiliti, kebolehpercayaan, dan keselamatan. Isu -isu utama termasuk kontena, mikroservis, reka bentuk tanpa kewarganegaraan, dan strategi pengoptimuman.

Bagaimanakah saya boleh membuat dan menggunakan peraturan pengesahan tersuai di Laravel? Bagaimanakah saya boleh membuat dan menggunakan peraturan pengesahan tersuai di Laravel? Mar 17, 2025 pm 02:38 PM

Artikel ini membincangkan membuat dan menggunakan peraturan pengesahan tersuai di Laravel, menawarkan langkah -langkah untuk menentukan dan melaksanakannya. Ia menyoroti faedah seperti kebolehgunaan semula dan kekhususan, dan menyediakan kaedah untuk memperluaskan sistem pengesahan Laravel.

Laravel vs Symfony: Mana yang sesuai untuk aplikasi web anda? Laravel vs Symfony: Mana yang sesuai untuk aplikasi web anda? Mar 10, 2025 pm 01:34 PM

Ketika datang untuk memilih kerangka PHP, Laravel dan Symfony adalah antara pilihan yang paling popular dan digunakan secara meluas. Setiap kerangka membawa falsafah, ciri, dan kekuatannya sendiri ke meja, menjadikannya sesuai untuk projek yang berbeza dan menggunakan kes -kes

Apakah cara terbaik untuk mengendalikan muat naik fail dan penyimpanan awan di Laravel? Apakah cara terbaik untuk mengendalikan muat naik fail dan penyimpanan awan di Laravel? Mar 12, 2025 pm 05:54 PM

Artikel ini meneroka strategi muat naik fail optimum dan penyimpanan awan di Laravel. Ia mengkaji penyimpanan storan tempatan berbanding pembekal awan (AWS S3, Google Cloud, Azure, DigitalOcean), menekankan keselamatan (pengesahan, sanitisasi, HTTPS) dan Opti Prestasi

See all articles