Pagination CakePHP

王林
Libérer: 2024-08-29 12:58:00
original
842 Les gens l'ont consulté

Dans CakePHP, nous avons différentes fonctionnalités pour le développeur, si nous voulons essayer de développer une application Web flexible et conviviale à ce moment-là, nous pouvons inclure le concept de pagination dans le framework. Afficher un nombre raisonnable d'enregistrements par page a toujours été un élément de base de chaque application et causait de nombreuses douleurs cérébrales aux concepteurs. CakePHP allège le poids du concepteur en offrant une méthode simple et rapide pour paginer les informations. L'un des principaux obstacles à la création d'applications Web adaptables et faciles à utiliser est la planification d'une interface utilisateur naturelle.

Commencez votre cours de développement de logiciels libres

Développement Web, langages de programmation, tests de logiciels et autres

Qu'est-ce que la pagination CakePHP ?

L'amélioration d'un point de connexion facile à utiliser est l'un des principaux enjeux pour les concepteurs d'applications Web car lorsque le client compose son code source, alors, à ce stade, la longueur du code et sa complexité augmentent. De même, la gestion de centaines ou de milliers de documents sur une seule page était difficile à gérer. En outre, il investit dans une opportunité de regrouper les subtilités sur une seule page grâce à laquelle l'application Web bénéficie d'une qualité inébranlable et de la satisfaction du client. Dans cette optique, les concepteurs de CakePHP offrent une capacité de pagination permettant de vaincre les nombreux enregistrements d'une seule page. De nombreuses applications se remplissent le plus souvent rapidement de taille et de complexité, et les architectes et les ingénieurs logiciels constatent qu'ils ne peuvent pas s'adapter à l'affichage de centaines ou de milliers d'enregistrements.

Pour afficher l'enregistrement des mouvements du client sur une seule page, alors, à ce stade, la longueur des enregistrements est excessivement longue, c'est pourquoi nous avons été confrontés à ces problèmes

Le client doit parcourir différents moments pour voir les données.

Il ne sera pas difficile de parcourir le site sur des gadgets compacts comme des téléphones portables, des tablettes, etc.
Cela diminuera l'exécution de l'application Web.

Dans ces circonstances, CakePHP présente une stratégie de pagination idéale.

Stratégie de pagination pour CakePHP : elle isole tous les enregistrements en parties équivalentes et montre un enregistrement solitaire au client comme indiqué par les besoins de l'application.

Modèle : supposons que nous avons 200 enregistrements sur chaque page et que nous devons afficher seulement 20 enregistrements. Comme pour les mathématiques de base, pour obtenir les feuilles complètes, c'est 200/20 = 10. Pour cette raison, nous voulons vraiment permettre au client de voir les subtilités de chaque page, soit sur un petit écran comme un gadget polyvalent ou dans un espace de travail. 🎜>

Comment configurer la pagination CakePHP ?

Voyons maintenant comment configurer la pagination dans CakePHP comme suit.

Parfois, nous voulons vraiment faire de la pagination dans CakePHP en utilisant une requête SQL conventionnelle ; par la suite, l'utilité de la pagination prédéfinie de CakePHP est perdue. Pagination personnalisée dans CakePHP

Nous pouvons mettre en œuvre une stratégie de pagination dans le modèle ou le comportement lorsque nous utilisons une requête SQL standard dans CakePHP. Il suffit simplement de s'assurer que le résultat ne peut pas être obtenu avec des techniques de modèle central ou un localisateur personnalisé avant d'effectuer la pagination des questions personnalisées. Cependant, nous ne pouvons pas simplement utiliser la pagination standard sur les questions personnalisées, nous devons abroger les capacités de pagination en matière de modèle ou de conduite.

Pour utiliser notre propre stratégie/justification pour remplacer la pagination CakePHP dans le modèle, nous souhaitons vraiment ajouter deux capacités : paginate() et paginateCount().

Pour afficher un tas d'informations colossales, on peut utiliser la pagination et ce composant est accessible avec cake PHP 4 qui est exceptionnellement simple à utiliser.

Dans la capture d'écran suivante, nous pouvons voir plusieurs entrées de base de données avec des valeurs différentes comme suit.

Nous devons maintenant afficher les enregistrements sur une seule page avec quelques entrées afin de pouvoir utiliser la pagination. Pour cette raison, nous devons d’abord configurer le fichier routes.php comme suit.

<?php
use Cake\Http\Middleware\CsrfProtectionMiddleware;
use Cake\Routing\Route\DashedRoute;
use Cake\Routing\RouteBuilder;
$routes->setRouteClass(DashedRoute::class);
$routes->scope('/', function (RouteBuilder $builder) {
$builder->registerMiddleware('csrf', new CsrfProtectionMiddleware([
'httpOnly' => true,
]));
$builder->applyMiddleware('csrf');
//$builder->connect('/pages',['controller'=>'Pages','action'=>'display', 'home']);
$builder->connect('posts',['controller'=>'Posts','action'=>'index']);
$builder->fallbacks();
});
Copier après la connexion
Nous devons maintenant créer le fichier contrôleur.php et écrire le code suivant comme suit.

<?php
namespace App\Controller;
use App\Controller\AppController;
class PostsController extends AppController {
public function index(){
$this->loadModel('rounds);
$articles = $this->rounds->find('all')->order(['rounds.id ASC']);
$this->set('rounds', $this->paginate($rounds, ['limit'=> '4']));
}
}
?>
Copier après la connexion

Explication

Dans le fichier ci-dessus nous écrivons la logique d'affichage des enregistrements, ici nous essayons d'afficher 4 enregistrements sur une seule page.

Maintenant, nous devons créer un répertoire et sous ce répertoire créer un nouveau fichier index.php et écrire le code suivant comme suit.

<div>
<?php foreach ($rounds as $key=>$rounds) {?>
<a href="#">
<div>
<p><?= $rounds->title ?> </p>
<p><?= $rounds->details ?></p>
</div>
</a>
<br/>
<?php
}
?>
<ul class="pagination">
<?= $this->Paginator->prev("<<") ?>
<?= $this->Paginator->numbers() ?>
<?= $this->Paginator->next(">>") ?>
</ul>
</div>
Copier après la connexion
Exécutez maintenant le code ci-dessus dans localhost. Le résultat final de la mise en œuvre ci-dessus que nous avons illustré en utilisant la capture d'écran suivante comme suit.

Using Controller Cakephp pagination

In the regulator, we start by characterizing the default question conditions pagination will use in the $paginate regulator variable. These circumstances serve as the reason for your pagination questions. They are increased by the sort, direction, limit, and page boundaries passed in from the URL. It is critical to note that the request key should be characterized in an exhibit structure like beneath:

class RoundController extends AppController
{
public $paginate = [
'limit' => 20,
'order' => [
'Round.title' => 'Desc'
]
];
public function initialize()
{
parent::initialize();
$this->loadComponent('Paginator');
}
}
Copier après la connexion

In this code, we can include different options that are supported by the find () method as per our requirements.

class RoundController extends AppController
{
public $paginate = [
'fields' => ['Rounds.id', 'Rounds.created'],
'limit' => 20,
'order' => [
'Rounds.title' => 'Desc'
]
];
public function initialize()
{
parent::initialize();
$this->loadComponent('Paginator');
}
}
Copier après la connexion

While you can pass the vast majority of the question choices from the paginate property it is often cleaner and more straightforward to wrap up your pagination choices into a Custom Finder Method. You can characterize the locater pagination utilizing finder choice.

Conclusion

From the above article, we have taken in the essential idea of the CakePHP pagination and we also see the representation and examples. From this article, we learned how and when we use the CakePHP pagination.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
php
source:php
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal
À propos de nous Clause de non-responsabilité Sitemap
Site Web PHP chinois:Formation PHP en ligne sur le bien-être public,Aidez les apprenants PHP à grandir rapidement!