Maison >cadre php >YII >Pagination dans le framework Yii : Optimisation de l'affichage des données

Pagination dans le framework Yii : Optimisation de l'affichage des données

PHPz
PHPzoriginal
2023-06-21 14:22:40888parcourir

Dans les applications Web, l'affichage des données est une fonction importante et fréquemment utilisée. Face à de grandes quantités de données, il est particulièrement important d’afficher et d’obtenir les données requises. La pagination joue un rôle décisif dans la réalisation de la fonction d'affichage des données.

Le framework Yii est un excellent framework d'application Web. Il fournit des fonctions de pagination puissantes et faciles à utiliser, qui peuvent nous aider à optimiser l'effet de l'affichage des données. Alors, comment utiliser la fonction de pagination dans le framework Yii ? Cet article présentera en détail comment utiliser la fonction de pagination dans le framework Yii pour optimiser l'affichage des données.

1. Définir la pagination dans le contrôleur

Dans le framework Yii, nous implémentons généralement la requête de données et le contrôle de pagination dans le contrôleur. Tout d'abord, vous devez interroger les données dans l'action du contrôleur et utiliser le téléavertisseur pour paginer les données.

// 控制器的action中查询数据
public function actionIndex()
{
    $query = News::find();
    
    // 使用yiidataPagination类实现分页功能
    $pagination = new yiidataPagination([
        'totalCount' => $query->count(),
        'pageSize' => 10
    ]);
    
    // 调用query的offset和limit方法对数据进行分页
    $models = $query->offset($pagination->offset)
        ->limit($pagination->limit)
        ->all();
        
    //将查询结果传递给视图
    return $this->render('index', [
        'models' => $models,
        'pagination' => $pagination
    ]);
}

Dans le code ci-dessus, nous interrogeons d'abord les données, puis utilisons la classe yiidataPagination dans Yii pour implémenter le contrôle de pagination. Parmi eux, l'attribut totalCount représente le nombre total de données, et l'attribut pageSize représente le nombre d'éléments affichés sur chaque page. Ensuite, nous appelons les méthodes offset et limit de la requête $query pour implémenter la pagination. Le décalage et la limite correspondent ici à LIMIT et OFFSET dans l'instruction SQL. Enfin, les résultats de la requête sont transmis à la vue pour affichage. yiidataPagination类来实现分页控制。其中,totalCount属性表示数据总数,pageSize属性表示每页显示的条目数。接着,我们调用查询$query的offset和limit方法实现分页,这里的offset和limit对应SQL语句中的LIMIT和OFFSET。最后,将查询结果传递给视图进行展示。

二、在视图中使用分页

在视图中,我们需要展示每一页的数据,同时提供对分页进行控制的操作,这需要我们在视图中使用分页器。

<?php
// 在视图中显示数据
foreach($models as $model) {
    // 显示每个数据项
}

// 使用yiiwidgetsLinkPager类实现分页器
echo yiiwidgetsLinkPager::widget([
    'pagination' => $pagination
]);
?>

上述代码中,我们首先使用foreach循环遍历每一页的数据,并将数据展示到视图中。然后,使用Yii中的yiiwidgetsLinkPager类实现分页器,其中的pagination属性对应的是分页控制对象。分页器会自动展示页码以及相关操作,比如跳转到指定页等操作。

三、优化分页效果

在使用分页器的过程中,我们还可以进行一些比较实用的优化。例如,可以调整显示链接的数量,增加前后翻页操作,或者在使用Ajax技术时,我们可以使用无刷新分页,避免重复加载。

//在Pagination中设置页面链接数量
$pagination->maxButtonCount = 5;
//在LinkPager中设置前后翻页按钮
echo yiiwidgetsLinkPager::widget([
    'pagination' => $pagination,
    'prevPageCssClass' => 'pagination-prev',
    'nextPageCssClass' => 'pagination-next'
]);
//在Ajax分页时,添加Js代码实现无刷新分页效果
$js = <<<JS
$('body').on('click', '.pagination a', function (e) {
    e.preventDefault();
    $.ajax({
        url: $(this).attr('href'),
        success: function(data){
            $('#result').html(data);
        }
    });
});
JS;
$this->registerJs($js);

上述代码中,我们可以通过在yiidataPagination对象中设置maxButtonCount属性来调整分页控件中的链接数量。在使用yiiwidgetsLinkPager

2. Utiliser la pagination dans la vue

Dans la vue, nous devons afficher les données de chaque page et fournir des opérations pour contrôler la pagination, ce qui nous oblige à utiliser un paginateur dans la vue.

rrreee

Dans le code ci-dessus, nous utilisons d'abord une boucle foreach pour parcourir les données de chaque page et afficher les données dans la vue. Ensuite, utilisez la classe yiiwidgetsLinkPager dans Yii pour implémenter le paginateur, où l'attribut de pagination correspond à l'objet de contrôle de pagination. Le paginateur affichera automatiquement les numéros de page et les opérations associées, telles que le passage à une page spécifiée. 🎜🎜3. Optimiser l'effet de pagination🎜🎜Dans le processus d'utilisation du paginateur, nous pouvons également effectuer des optimisations plus pratiques. Par exemple, vous pouvez ajuster le nombre de liens affichés et ajouter des opérations de rotation des pages recto et verso, ou lorsque vous utilisez la technologie Ajax, nous pouvons utiliser une pagination sans actualisation pour éviter des chargements répétés. 🎜rrreee🎜Dans le code ci-dessus, nous pouvons ajuster le nombre de liens dans le contrôle de pagination en définissant la propriété maxButtonCount dans l'objet yiidataPagination. Lors de l'utilisation du contrôle yiiwidgetsLinkPager, nous pouvons utiliser les propriétés prevPageCssClass et nextPageCssClass pour contrôler le style de rotation des pages en avant et en arrière. Lors de l'utilisation de la technologie Ajax, nous pouvons ajouter du code Js d'enregistrement dans la vue pour obtenir un effet de pagination sans actualisation. 🎜🎜Résumé🎜🎜Dans le framework Yii, la pagination est une partie importante. À l'aide du contrôle de pagination, vous pouvez facilement réaliser l'affichage de pagination des données et améliorer l'expérience utilisateur. Dans le développement réel, il doit être utilisé de manière flexible en fonction des différents besoins et scénarios commerciaux. Cet article présente comment utiliser la pagination dans le framework Yii. L'exemple de code n'est qu'une implémentation de base et doit être ajusté et optimisé en fonction d'une logique métier spécifique. 🎜

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!

Déclaration:
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