Rumah > pembangunan bahagian belakang > tutorial php > Langkah-langkah untuk melaksanakan pengisihan dan pengisihan data menggunakan rangka kerja CakePHP

Langkah-langkah untuk melaksanakan pengisihan dan pengisihan data menggunakan rangka kerja CakePHP

王林
Lepaskan: 2023-08-03 14:42:01
asal
1460 orang telah melayarinya

Langkah-langkah untuk melaksanakan pengisihan dan pengisihan data menggunakan rangka kerja CakePHP

Dengan pembangunan aplikasi web, keperluan untuk memproses sejumlah besar data menjadi semakin biasa. Dalam rangka kerja CakePHP, melaksanakan pengisihan dan pengisihan data adalah salah satu keperluan yang paling biasa. Melalui paging, kami boleh membahagikan sejumlah besar data kepada berbilang halaman untuk paparan bagi mengurangkan tekanan pemuatan halaman dan melalui pengisihan, kami boleh mengisih dan memaparkan data mengikut keadaan tertentu, menjadikannya lebih mudah untuk pengguna menyemak imbas data. Artikel ini akan memperkenalkan cara menggunakan rangka kerja CakePHP untuk melaksanakan pengisihan dan pengisihan data.

Langkah 1: Buat jadual dan model pangkalan data

Pertama, kita perlu mencipta jadual pangkalan data untuk menyimpan data yang perlu dipaparkan. Katakan kita mencipta jadual bernama "pengguna" yang mengandungi medan seperti "id", "nama" dan "umur". Seterusnya, kita perlu mencipta model untuk jadual. Dalam rangka kerja CakePHP, model digunakan untuk menyambungkan jadual pangkalan data dan aplikasi, dan menyediakan fungsi seperti pertanyaan data, sisipan, kemas kini dan pemadaman.

Dalam terminal baris arahan, gunakan arahan berikut untuk mencipta model bernama Pengguna:

bin/cake bake model User
Salin selepas log masuk

Arahan ini secara automatik akan menjana model Pengguna yang mengandungi sifat dan kaedah yang sepadan dengan medan jadual pangkalan data.

Langkah 2: Konfigurasikan paging

Dalam rangka kerja CakePHP, konfigurasi paging adalah sangat mudah. Mula-mula, tambahkan kod berikut pada Pengawal kami:

public $paginate = [
    'limit' => 10, // 每页显示的记录数
    'order' => [
        'User.name' => 'asc' // 默认按照name字段升序排列
    ]
];
Salin selepas log masuk

Dalam kod di atas, kami mentakrifkan konfigurasi halaman dengan menetapkan atribut $paginate. Dalam medan had, kami menyatakan bilangan rekod yang dipaparkan pada setiap halaman, di sini ia ditetapkan kepada 10. Dalam medan order, kami menentukan medan pengisihan lalai dan kaedah pengisihan, yang disusun dalam tertib menaik mengikut medan nama. $paginate属性来定义分页的配置。在limit字段中,我们指定了每一页显示的记录数,这里设置为10条。在order字段中,我们指定了默认的排序字段和排序方式,这里按照name字段升序排列。

步骤三:定义分页和排序的方法

接下来,我们需要在控制器中定义两个方法,一个用于分页,另一个用于排序。例如,我们可以在控制器的index方法中添加以下代码:

public function index()
{
    $this->paginate['order'] = ['User.name' => 'asc']; // 按照name字段升序排列
    $this->set('users', $this->paginate($this->User));
}

public function sort()
{
    $field = $this->request->getQuery('field');
    $direction = $this->request->getQuery('direction');

    if ($field && $direction) {
        $this->paginate['order'] = [$field => $direction];
    }

    $this->set('users', $this->paginate($this->User));
}
Salin selepas log masuk

在上述代码中,我们在index方法中通过$this->paginate()方法进行分页查询,并将结果传递给视图(View)层进行显示。

sort方法中,我们通过请求的查询参数获取排序的字段和方式,并进行相应的设置。

步骤四:在视图中显示分页和排序的链接

最后,在我们的视图(View)文件中添加分页和排序的链接,以及展示数据的代码。例如,我们可以在index.ctp文件中添加以下代码:

<table>
    <thead>
        <tr>
            <th><?php echo $this->Html->link('Name', ['action' => 'sort', 'field' => 'name', 'direction' => 'asc']); ?></th>
            <th><?php echo $this->Html->link('Age', ['action' => 'sort', 'field' => 'age', 'direction' => 'asc']); ?></th>
        </tr>
    </thead>
    <tbody>
        <?php foreach ($users as $user): ?>
            <tr>
                <td><?php echo h($user->name); ?></td>
                <td><?php echo h($user->age); ?></td>
            </tr>
        <?php endforeach; ?>
    </tbody>
</table>

<?php echo $this->Paginator->prev('上一页'); // 上一页链接 ?>
<?php echo $this->Paginator->numbers(); // 分页数字链接 ?>
<?php echo $this->Paginator->next('下一页'); // 下一页链接 ?>
Salin selepas log masuk

以上代码中,我们使用CakePHP框架提供的HtmlPaginator

Langkah 3: Tentukan kaedah paging dan sorting

Seterusnya, kita perlu menentukan dua kaedah dalam pengawal, satu untuk paging dan satu lagi untuk sorting. Sebagai contoh, kita boleh menambah kod berikut dalam kaedah index pengawal: 🎜rrreee🎜Dalam kod di atas, kami menghantar $this-&gt dalam <code>index kaedah Kaedah ;paginate() menjalankan pertanyaan penomboran dan menghantar keputusan ke lapisan paparan untuk paparan. 🎜🎜Dalam kaedah isih, kami memperoleh medan pengisihan dan kaedah melalui parameter pertanyaan yang diminta, dan menetapkannya dengan sewajarnya. 🎜🎜Langkah 4: Paparkan pautan halaman dan isihan dalam paparan🎜🎜Akhir sekali, tambahkan pautan halaman dan isihan, serta kod untuk memaparkan data, dalam fail paparan (Lihat) kami. Sebagai contoh, kami boleh menambah kod berikut pada fail index.ctp: 🎜rrreee🎜Dalam kod di atas, kami menggunakan Html dan Paginator disediakan oleh rangka kerja CakePHP >Kaedah tambahan menjana pautan halaman dan pengisihan, serta jadual yang memaparkan data bernombor. 🎜🎜Melalui langkah di atas, kami boleh melaksanakan fungsi pengisihan dan halaman data dalam rangka kerja CakePHP. Konfigurasikan paging dalam pengawal, tentukan kaedah paging dan sorting, dan paparkan pautan paging dan sorting dalam paparan, serta kod untuk memaparkan data. Ini membolehkan pengguna menyemak imbas dan mengisih sejumlah besar data dengan mudah. 🎜

Atas ialah kandungan terperinci Langkah-langkah untuk melaksanakan pengisihan dan pengisihan data menggunakan rangka kerja CakePHP. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:php.cn
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
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan