1. Prinsip paging
Sebelum memperkenalkan fungsi paging ThinkPHP, mari kita fahami prinsip asas paging.
Kandungan di tapak web adalah kaya dan berwarna-warni, tetapi untuk kandungan dengan jumlah data yang besar, jika ia diletakkan pada satu halaman, halaman akan dimuatkan dengan perlahan, menjejaskan pengalaman pengguna, dan ia juga akan meningkat kesukaran pengurusan data. Oleh itu, paging telah menjadi kaedah biasa untuk menyelesaikan masalah ini.
Prinsip asas data halaman adalah untuk memisahkan data kepada beberapa halaman, dan setiap halaman memaparkan jumlah data yang tetap. Biasanya, terdapat dua cara paging: satu adalah paging berdasarkan pernyataan SQL, dan yang lain adalah paging berdasarkan tatasusunan.
2. paging berasaskan SQL
Dalam ThinkPHP, paging dilaksanakan berdasarkan pernyataan SQL. Kita boleh menggunakan kaedah limit
yang disediakan oleh ThinkPHP untuk melaksanakan pertanyaan paging. Berikut ialah contoh mudah:
//获取分页数据,每页显示10条数据 $users = Db::name('user')->order('id desc')->limit(10)->select();
Dalam kod di atas, Db::name('user')
mewakili pertanyaan data jadual user
, pernyataan order('id desc')
mewakili pengisihan dalam tertib menurun mengikut medan id
, dan limit(10)
mewakili paparan pada setiap halaman 10 keping data.
Seterusnya, kami juga perlu menambah bar navigasi paging pada halaman templat. Dalam ThinkPHP, kita boleh menggunakan kaedah paginate
untuk menjana bar navigasi halaman, seperti yang ditunjukkan dalam contoh berikut:
//每页显示10条数据 $users = Db::name('user')->paginate(10); //将分页数据赋值到模板中 $this->assign('users', $users); //在模板中输出分页数据 {{$users|raw}}
Dalam kod di atas, paginate(10)
bermaksud memaparkan 10 keping data setiap halaman, dan kaedah $this->assign
digunakan Berikan data paging kepada templat, dan kod {{$users|raw}}
digunakan untuk mengeluarkan data paging. Dengan cara ini, kami boleh memaparkan bar navigasi halaman pada halaman.
3. Paging berasaskan tatasusunan
Selain paging berasaskan SQL, ThinkPHP juga menyediakan paging berasaskan tatasusunan. Dalam kebanyakan kes, paging berasaskan tatasusunan adalah lebih fleksibel daripada paging berasaskan SQL.
Dalam ThinkPHP, kita boleh menggunakan fungsi array_slice
untuk melaksanakan halaman berasaskan tatasusunan, seperti yang ditunjukkan dalam contoh berikut:
//数据总数 $count = count($data); //每页显示10条数据 $pagesize = 10; //当前页 $page = input('page', 1); //计算总页数 $pagecount = ceil($count / $pagesize); //起始位置 $start = ($page - 1) * $pagesize; //获取当前页的数据 $list = array_slice($data, $start, $pagesize); //将分页数据赋值到模板中 $this->assign('list', $list); //在模板中输出分页数据 {{$list|raw}}
Dalam kod di atas, count($data)
mewakili jumlah bilangan daripada data, $pagesize
Mewakili jumlah data yang dipaparkan pada setiap halaman, input('page', 1)
mewakili mendapatkan nombor halaman semasa, jika tidak diperoleh, ia lalai ke halaman pertama, ceil($count / $pagesize)
mewakili jumlah bilangan halaman, ($page - 1) * $pagesize
mewakili kedudukan permulaan, dan akhirnya menggunakan fungsi array_slice
Dapatkan data halaman semasa. Kemudian tetapkan data paging pada templat dan gunakan {{$list|raw}}
untuk mengeluarkan data paging.
Atas ialah kandungan terperinci Apakah kaedah untuk melaksanakan fungsi paging dalam thinkphp. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!