Lapozás a Codeigniterben lépésről lépésre példával

Az adatbázisok élőlények. Az idő múlásával nőnek. Az alkalmazások tervezésénél figyelembe kell vennünk azt a sok rekordot, amelyet a felhasználóknak át kell böngészni. A lapozás lehetővé teszi, hogy eredményeinket kis, kezelhető részekre bontsuk. A következő kép egy példát mutat oldalszámozásra a Google keresőben.

Lapozás a Codeigniterben

Ebben az oktatóanyagban megtudhatja, hogyan lapozhatja az adatbázis-eredményeket a CodeIgniterben a lapozási könyvtár használatával. Ez az oktatóanyag feltételezi, hogy ismeri a CodeIgniter Active Record alapjait. Ha nem, akkor elolvashatja a korábbi oktatóanyagokat. A másik feltételezés az, hogy már letöltötte a CodeIgnitert.

Adatbázis konfiguráció

Kezdjük az adatbázis létrehozásával és néhány álrekord beszúrásával. Ez egy egytáblás adatbázis lesz, 50 rekorddal.

Futtassa a következő szkriptet ellen MySQL az adatbázis szerzői tábla létrehozásához. Illesszen be 50 álrekordot.

CREATE SCHEMA ci_pagination;

DROP TABLE IF EXISTS `authors`;

CREATE TABLE `authors` (
  `id` int(11) NOT NULL AUTO_INCREMENT,
  `first_name` varchar(50) COLLATE utf8_unicode_ci NOT NULL,
  `last_name` varchar(50) COLLATE utf8_unicode_ci NOT NULL,
  `email` varchar(100) COLLATE utf8_unicode_ci NOT NULL,
  `birthdate` date NOT NULL,
  `added` timestamp NOT NULL DEFAULT current_timestamp(),
  PRIMARY KEY (`id`),
  UNIQUE KEY `email` (`email`)
) ENGINE=InnoDB AUTO_INCREMENT=101 DEFAULT CHARSET=utf8 COLLATE=utf8_unicode_ci;
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (1, 'Brielle', 'O\'Hara', 'alexandre67@example.com', '1974-05-21', '1999-09-17 19:17:28');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (2, 'Flavio', 'Lehner', 'mafalda85@example.net', '1971-10-14', '1998-09-09 00:25:06');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (3, 'Elmira', 'Johns', 'wellington52@example.org', '1983-11-28', '2015-02-07 15:56:43');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (4, 'Elza', 'Mitchell', 'marisol46@example.org', '1989-03-08', '1992-08-21 00:21:39');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (5, 'Viva', 'Greenfelder', 'era94@example.com', '1995-04-17', '2017-04-30 05:55:39');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (6, 'Maxwell', 'VonRueden', 'mcassin@example.net', '1994-07-01', '1996-05-08 23:30:14');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (7, 'Deontae', 'Becker', 'rory.kub@example.org', '1992-02-19', '2017-07-22 11:49:15');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (8, 'Sylvester', 'Christiansen', 'erohan@example.org', '1990-09-03', '2004-05-08 08:15:37');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (9, 'Torrey', 'Strosin', 'adams.luciano@example.net', '1999-10-09', '2009-08-30 21:30:44');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (10, 'Kelli', 'Smitham', 'daniel.catalina@example.com', '2012-11-07', '1986-01-22 20:52:57');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (11, 'Abigale', 'Schuppe', 'andreanne.hayes@example.net', '2018-02-18', '1994-05-07 06:26:36');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (12, 'Letha', 'Gleason', 'eldridge.heaney@example.net', '2009-02-06', '1998-05-25 04:37:54');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (13, 'Sienna', 'Upton', 'monique57@example.org', '2017-08-17', '2009-08-08 19:08:10');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (14, 'Harley', 'Gutkowski', 'breilly@example.net', '1987-11-30', '1998-07-31 11:08:01');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (15, 'Lois', 'Bednar', 'hpouros@example.net', '2002-02-11', '2001-07-26 15:04:16');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (16, 'Gail', 'McDermott', 'reina.kerluke@example.com', '1987-03-30', '2004-12-15 20:38:29');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (17, 'Sydney', 'Strosin', 'dweber@example.net', '1985-04-29', '2010-08-07 08:50:35');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (18, 'Anne', 'Cremin', 'fritz.schmitt@example.com', '1976-02-15', '1980-03-25 05:29:41');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (19, 'Norberto', 'Bergnaum', 'franecki.javon@example.net', '1971-03-11', '1993-03-20 23:36:25');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (20, 'Arvid', 'Johns', 'pschultz@example.org', '2016-01-03', '1995-04-30 17:07:15');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (21, 'Bernita', 'Fay', 'arne96@example.org', '1983-12-26', '1987-02-23 16:55:28');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (22, 'Gonzalo', 'Gorczany', 'velma.huels@example.com', '1987-10-19', '2016-10-18 19:25:46');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (23, 'Jackie', 'Klein', 'gretchen.howe@example.com', '1971-01-20', '2010-11-16 02:58:05');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (24, 'Andrew', 'Kessler', 'collins.faye@example.org', '1984-08-07', '1971-12-15 08:46:42');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (25, 'Claire', 'Hudson', 'madalyn.wunsch@example.org', '1984-12-19', '1991-07-04 14:35:53');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (26, 'Prudence', 'Runte', 'koch.laurie@example.net', '2008-12-27', '1985-09-30 04:57:55');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (27, 'Destinee', 'Romaguera', 'tromp.tiffany@example.com', '1978-11-09', '1997-11-09 19:58:08');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (28, 'Marianna', 'Harvey', 'clovis.schuppe@example.com', '2013-08-28', '1990-08-06 19:29:19');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (29, 'Eloy', 'Lakin', 'wmorissette@example.net', '1989-12-08', '1974-03-16 03:21:16');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (30, 'Rubie', 'McClure', 'haley.louisa@example.net', '1987-09-12', '1998-07-02 10:45:36');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (31, 'Marisa', 'Stracke', 'zachary76@example.org', '1975-05-28', '1975-03-19 00:57:35');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (32, 'Jacey', 'Beatty', 'dahlia.hermann@example.org', '1979-12-17', '1971-01-21 16:50:58');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (33, 'Idella', 'Ruecker', 'elda.reichert@example.com', '2009-09-15', '1996-04-19 22:27:31');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (34, 'Dimitri', 'Bednar', 'freida.parker@example.org', '1998-12-02', '2008-12-30 23:29:57');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (35, 'Elfrieda', 'Smitham', 'padberg.rex@example.org', '2018-07-23', '1972-04-01 07:52:25');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (36, 'Dwight', 'Walter', 'gmosciski@example.org', '2016-08-15', '1994-07-02 11:06:55');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (37, 'Macie', 'Fay', 'uschuppe@example.net', '1976-01-29', '2005-12-13 18:44:46');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (38, 'Lori', 'Kshlerin', 'mhansen@example.net', '1983-04-08', '1986-01-18 16:03:52');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (39, 'Jeffry', 'Paucek', 'alisha35@example.net', '2002-10-02', '2004-03-29 07:06:03');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (40, 'Yvonne', 'Bernhard', 'jaqueline21@example.net', '2017-11-04', '1986-12-15 23:55:23');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (41, 'Ludwig', 'Heathcote', 'marcelino.kirlin@example.org', '1981-02-09', '2000-08-02 20:45:48');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (42, 'Jadyn', 'Wiegand', 'georgianna.swift@example.net', '1982-06-16', '1980-12-05 13:09:37');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (43, 'Ferne', 'Smitham', 'melany22@example.com', '1996-12-17', '1984-11-18 19:26:27');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (44, 'Meta', 'Corkery', 'xharber@example.com', '1972-03-31', '2007-01-20 00:07:31');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (45, 'Toni', 'Wolf', 'wyman.crystal@example.org', '2012-04-15', '1973-06-22 12:14:37');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (46, 'Zack', 'Luettgen', 'deion.konopelski@example.org', '2003-05-29', '2018-11-19 05:03:21');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (47, 'Kameron', 'Dietrich', 'ronaldo.torphy@example.com', '1973-05-20', '1974-09-16 20:27:17');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (48, 'Zetta', 'Lebsack', 'timmothy.vandervort@example.com', '1996-11-04', '2001-03-06 01:33:01');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (49, 'Benny', 'Hane', 'leone.lueilwitz@example.net', '2008-02-02', '2006-01-27 22:12:39');
INSERT INTO `authors` (`id`, `first_name`, `last_name`, `email`, `birthdate`, `added`) VALUES (50, 'Evans', 'Gleason', 'ccummerata@example.org', '1999-09-09', '1990-09-26 17:50:11');

Most, hogy sikeresen létrehoztuk az adatbázisunkat, és álrekordokat illesztettünk bele, állítsuk be a CodeIgniter alkalmazásunkat, hogy kommunikáljon az adatbázissal.

Nyissa meg az application/config/database.php fájlt

Állítsa be az adatbázis-kapcsolat paramétereit az alábbiakhoz hasonlóan

$db['default'] = array(
	'dsn'	=> '',
	'hostname' => 'localhost',
	'username' => 'root',
	'password' => 'melody',
	'database' => 'ci_pagination',
	'dbdriver' => 'mysqli',
	'dbprefix' => '',
	'pconnect' => FALSE,
	'db_debug' => (ENVIRONMENT !== 'production'),
	'cache_on' => FALSE,
	'cachedir' => '',
	'char_set' => 'utf8',
	'dbcollat' => 'utf8_general_ci',
	'swap_pre' => '',
	'encrypt' => FALSE,
	'compress' => FALSE,
	'stricton' => FALSE,
	'failover' => array(),
	'save_queries' => TRUE
);

ITT,

  • 'hostname' => 'localhost', beállítja az adatbázis hosztnevét
  • 'username' => 'root', az adatbázis nevét adja meg
  • 'password' => 'openseseme', beállítja az adatbázis jelszavát
  • 'database' => 'ci_pagination', az adatbázis nevét adja meg.

Az adatbázis-könyvtárat is automatikusan betöltjük, amikor alkalmazásunk elindul. Csináljuk meg. Nyissa meg az application/config/autoload.php fájlt

Töltse be az adatbázis-könyvtárat az alábbi kód szerint

$autoload['libraries'] = array('database');

Ennyi az adatbázis konfigurációhoz.

Most dolgozzunk az oldalszámozás adatbázismodelljén

CodeIgniter lapozási adatbázis-modell

Hozzon létre egy új Authors_model modellt az alkalmazásban/modellekben

Adja hozzá a következő kódot

<?php

class Authors_model extends CI_Model {

    protected $table = 'authors';

    public function __construct() {
        parent::__construct();
    }

    public function get_count() {
        return $this->db->count_all($this->table);
    }

    public function get_authors($limit, $start) {
        $this->db->limit($limit, $start);
        $query = $this->db->get($this->table);

        return $query->result();
    }
}

ITT,

  • védett $tábla = 'szerzők'; definiáljon egy védett változót, amely meghatározza a modell adatbázistábla nevét
  • public függvény __construct() {…} meghívja a szülő konstruktor metódust
  • public függvény get_count() {…} az adatbázistábla összes rekordját adja vissza. Erre oldalszámozási célból van szükség
  • public függvény get_authors($limit, $start) {…} definiál egy metódust, amely az adatbázisból oldalszámozott eredmények lekérésére szolgál. A határon és a kiindulási ponton áthaladunk. A korlát határozza meg a visszaküldendő rekordok számát, míg a start határozza meg az átugorandó rekordok számát

ennyi az adatbázis-modellünkhöz. Most hozzuk létre azokat az útvonalakat, amelyek válaszolni fognak oldalszámozott találatainkra.

CodeIgniter lapozási útvonalak

Nyissa meg az routes fájlt az application/config/routes.php fájlban

Adja hozzá a következő útvonalat

$route['authors/(:num)'] = 'authors';

ITT,

  • Meghatározunk egy útvonal-szerzőt, amely elfogadja a szám opcionális paraméterét. Az opcionális paramétert a nyitó és záró zárójelek határozzák meg. A meghatározott útvonal meghívja az index metódust a Authors vezérlőben.

Térjünk át a vezérlőre oldalszámozott eredményekért

CodeIgniter lapozásvezérlő

Hozzon létre egy új Authors.php fájlt az Application/controllers könyvtárban

Adja hozzá a következő kódot

<?php defined('BASEPATH') OR exit('No direct script access allowed');

class Authors extends CI_Controller {

    public function __construct() {
        parent:: __construct();

        $this->load->helper('url');
        $this->load->model('authors_model');
        $this->load->library("pagination");
    }

    public function index() {
        $config = array();
        $config["base_url"] = base_url() . "authors";
        $config["total_rows"] = $this->authors_model->get_count();
        $config["per_page"] = 10;
        $config["uri_segment"] = 2;

        $this->pagination->initialize($config);

        $page = ($this->uri->segment(2)) ? $this->uri->segment(2) : 0;

        $data["links"] = $this->pagination->create_links();

        $data['authors'] = $this->authors_model->get_authors($config["per_page"], $page);

        $this->load->view('authors/index', $data);
    }
}

ITT,

  • osztály Authors kiterjeszti CI_Controller {…} definiálunk egy osztályt Authors, amely kiterjeszti a CI_Controller osztályt
  • public function __construct() {…} ez a metódus inicializálja a szülő konstruktort, és betölti az url helpert, a szerzői modellt és a lapozási könyvtárat.
  • public function index() {…} határozza meg azt a metódust, amely válaszol az útvonal szerzőinknek
    • $config["alap_url"] = alap_url() . "szerzői"; beállítja az oldalszámozási linkek generálásához használt oldalszámozási URL-t
    • $config["összes_sorok"] = $this->authors_model->get_count(); beállítja az oldalszámozásra szoruló összes sort. Az érték a szerzői modellből a get_count metódus meghívásával kerül leolvasásra.
    • $config["oldalonként"] = 10; meghatározza az oldalanként megjelenítendő sorokat
    • $config["uri_szegmens"] = 2; megadja azt az URL-szegmenst, amely tartalmazza a rekordok átugrásához használt értéket
    • $ez->lapozás->inicializálás($config); inicializálja a lapozási könyvtárat az általunk meghatározott konfigurációs tömb értékével, és hozzárendeli a fenti értékeket.
    • $oldal = ($this->uri->szegmens(2)) ? $ez->uri->szegmens(2) : 0; ellenőrzi, hogy az URI második szegmensében be van-e állítva a kihagyási szám, és ha nincs beállítva, akkor a $page változóhoz 0 értéket rendel
    • $adat["linkek"] = $ez->lapozás->linkek_létrehozása(); létrehozza a lapozási hivatkozásokat, és hozzárendeli azokat a $data tömbváltozó linkkulcsához.
    • data['authors'] = $this->authors_model->get_authors($config["oldalonként"], $oldal); lekérte a lapozott szerzői rekordokat és hozzárendeli őket a $data tömb változó szerzői kulcsához
    • $this->load->view('authors/index', $data); betölti az indexnézetet a authors könyvtárba, és átadja a $data tömbváltozót.

A mi modellünknek ennyi. Most hozzuk létre azt a nézetet, amely megjeleníti az adatbázisunk eredményeit.

Hozzon létre egy új szerzői könyvtárat az alkalmazásban/nézetekben

Hozzon létre egy új index.php fájlt az application/views/authors/index.php fájlban

Adja hozzá a következő kódot

<!DOCTYPE html>
<html>
    <head>
        <title>CodeIgniter Pagination</title>
        <meta charset="UTF-8">
        <meta name="viewport" content="width=device-width, initial-scale=1.0">
        <link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/bulma/0.7.2/css/bulma.min.css">
    </head>
    <body>
        <div class="container">
            <h3 class="title is-3">CodeIgniter Database Pagination</h3>
            <div class="column">
                <table class="table is-bordered is-striped is-narrow is-hoverable is-fullwidth">
                    <thead>
                        <tr>
                            <th>ID</th>
                            <th>Contact Name</th>
                            <th>Contact Number</th>
                            <th>Email</th>
                            <th>City</th>
                        </tr>
                    </thead>
                    <tbody>
                        <?php foreach ($authors as $author): ?>
                            <tr>
                                <td><?= $author->id ?></td>
                                <td><?= $author->first_name ?></td>
                                <td><?= $author->last_name ?></td>
                                <td><?= $author->email ?></td>
                                <td><?= $author->birthdate ?></td>
                            </tr>
                        <?php endforeach; ?>
                    </tbody>
                </table>
                <p><?php echo $links; ?></p>
            </div>
        </div>
    </body>
</html>

ITT,

  • végigfut az $authors változó eredményein, és kiírja az eredményeket táblázatba
  • táblázatunk aljára nyomtatja ki az oldalszámozási hivatkozásokat.

Most indítsuk el az alkalmazásunkat, és nézzük meg az eredményeket

Ebben az oktatóanyagban a beépített PHP webszervert használjuk, de bármilyen webszervert használhat, amely támogatja PHP.

Nyissa meg a terminált

Futtassa a következő parancsot

cd C:\Sites\ci-app
php -S localhost:3000

ITT,

  • A fenti parancs tallózással az alkalmazás kódkönyvtárába lép, és elindítja a beépített szervert a 3000-es porton.

Megjegyzés: az alkalmazás elérési útjának meg kell egyeznie azzal az elérési úttal, ahová letöltötte a CodeIgnitert. Ehhez bármilyen ingyenes portszámot használhat a számítógépén. Nem szükséges a 3000-es portot használni.

Nyissa meg a webböngészőt, és töltse be a következő URL-t

http://localhost:3000/authors

Az alábbiakhoz hasonló eredményeket kell tudnia elérni

CodeIgniter lapozásvezérlő

Összegzésként

Ebben az oktatóanyagban bemutattuk az oldalszámozás alapjait, és kihasználtuk a lapozási könyvtár előnyeit CodeIgniter és egy adatbázis-eredményeket lapozó alkalmazás létrehozására használta.