Skip to content Skip to sidebar Skip to footer

Teknik Paging Di Php



Paging atau penomoran halaman yang Saya maksud disini adalah, membagi setiap data yang ditampilkan perhalaman sesuai dengan keinginan, contohnya ada 8 data, dari 8 data itu kita dapat mengatur perhalamannya untuk ditampilkan 1, 2, 3 dst. Sederhananya kalau diimplementasikan, ini menyerupai – menyerupai mirip derma (penomoran) halaman pada artikel blog.

Saya akan mengambarkan ini sesuai dengan apa yang saya pahami, kalau keliru mohon untuk diluruskan, agar  tidak terjadi salah paham atau salah dalam memahami. Saya tidak akan eksklusif mempersembahkan kode, namun akan mencoba terlebih lampau mengambarkan instruksi perbarisnya, sehingga nanti dapat paham dengan instruksi yang dituliskan.

Makara disini contohnya saya mempunyai sebuah tabel siswa yang meliputi 8 data, kemudian saya akan menampilkan 4 data per setiap halamannya. Langsung saja kita mulai

Teknik Pagging di PHP
#1 Kita akan buat kondisi awal, query dan saat terjadi sebuah requet halaman memakai GET
 
$awal=0;
$byk_tampil=4;


Maksud instruksi diatas yaitu memilih kondisi awal bernilai 0 data dan nilai data yang akan ditampilkan perhalamannya yaitu sebanyak 4 data

if(isset($_GET['hal'])){
    $awal=$_GET['hal']*$byk_tampil;
}
 
Maksud instruksi diatas yaitu kalau terjadi get maka kondisinya akan berubah nilai get dikali jmlh banyak tampil, kalau ada 8 data kemudian dibagi empat maka derma data akan terbagi dua, 1x4=4, 2x4=8, begitupun kalau misal jumlah data ada 16, 1x4=4 2x4=8, 4x3=12, 4x4=16. melaluiataubersamaini catatan, nilai 1 berarti dihitung sebagai 0 dan nilai 2 yaitu 1, dan 3 yaitu 2, nilai get ini akan merubah nilai variabel $awal pada limit data.

#2Membuat Query dan Limit Data


$perintah="SELECT * FROM tpdb_daftar";

Membuat variabel untuk melimit nilainya sesuai jumlah data yang ingin ditampilkan
 $limit="limit $awal,$byk_tampil"; 

Selanjutnya simpan dalam variabel $per_limit yang juga meliputi query data
 $per_limit=sprintf("%s %s",$perintah,$limit);

Query pertama bertuga menampilkan data tanpa melimitnya
 $allquery=mysqli_query($koneksi, $perintah);
 
Perintah selanjutnya yaitu query dengan menambahkan limit didalamnya
 $per_laman=mysqli_query($koneksi,$per_limit); 

 Menjumlahkan data kemudian ini nantinya akan dibagi datanya, sehingga query yang dijalankannya pun tidak dilimit
$jumlah=mysqli_num_rows($allquery);

#3 Melakukan Perulangan Untuk Menampilkan Data
Memulai penomoran/pengurutan data dari database, kalau $no diaktfikan menggantikan $id maka penomoran data akan dimulai dari angka 1, penomoran ini sama sekali tidak ada hubungannya dengan pagging atau derma halaman, tapi mengurutkan spesialuntuk mengurutkan data dari nilai 1

$no=$awal+1; //variabel $no yang berarti 0+1
//proses perulang dengan meilimit data sesuai dengan data yang ingin ditampilkan perhalaman
while($data=mysqli_fetch_array($per_laman)){
<tr>
<td><?php echo $data['id'] ?></td>
<td><?php echo $data['nama_siswa'];?></td>
<td><?php echo $data['sekolah'];?></td>
<td><?php echo $data['status_siswa'];?></td>
</tr>
<?php $no+=1;}?>
//selanjutnya berarti 0+1=1, nomor data dimulai dari 1 kalau engkau pake variabel $no 

#4 Membuat Pagging atau Penomoran Halaman

Proses pertama membuat variabel untuk url halamannya
$ke="pengumuman";
Ini dapat kita atur nilai variabelnnya kalau memang Anda pake pengaturan di httaccess, ini untuk urlnya, dapat saja nilainya meliputi $_GET['PHP_SELF']
$page=ceil($jumlah/4);
$jumlah diambil dari query mysqli_num_rows sebelumnya

Selanjutnya buat variabel yang meliputi jumlah data yang dibagi, misal 8:8=1 berati jumlah data akan dibagi 8, ini untuk nomor halamannya, kalau misal ada 16 data kemudian dibagi 4, maka penomoran halamannya akan dibagi menjadi 4 penomoran, dimana nilai 1 akan dihitung sebagai 0, 2 sebagai 1 dan seterusnya, 

$pg=1;
Buat variabel nilai awalnya

Kemudian lakukan perulangan menyerupai diberikut

while($pg<=$page){
Jika $pg lebih kecil atau sama dengan $page 1=1, contohnya kondisi data disini yaitu ada 8,  terus nanti dibagi 4 berarti nilai 2, nah kondisinya nanti berarti 1<=2

$hal=$pg-1;
maka nanti $hal 1-1=0, kalau $hal=0 maka saat request/klik angka 1 di url akan terlihat menjadi data 0

echo " <a href=\"$ke?hal=$hal\">$pg</a>";
Kode diatas akan dimulai request get

$pg+=1;

Selanjutnya perulangan data akan dilakukan hingga kondisi terpenuhi, kalau misal kondisinya 8:4=2, maka 1<=2 dan data akan diulang hingga nilai 2, kalau misal jmlah datanya 16 maka 16:4=4, maka halaman akan bernilai 1:4, sehingga $pg+ akan diulang hingga 4 penomoran, kalau kondisi tidak terpenuhi maka tidak akan ada pengulangan nomor pada halaman

Halaman :<?php echo" $hal dari $page";?>
Maksudnya  nanti akan mengambarkan berada di halaman berapa dari  jumlah halaman berapa $hal=$pg-1; (1-1=0)   dan $pg+=1;  (0+=1)

#5 Terkhir
Jika tiruana instruksi diatas digabungkan, maka alhasil kurang lebih akan terlihat menyerupai diberikut ini, pola :

<?php //panggil file css dan head yang terpisah include ('system/inc/head.php'); include ('system/inc/css.php'); include ('system/inc/navi.php'); include('system/conf/psb-koneksi.php'); //kondisi awal $awal=0; $byk_tampil=4; //jumlah data yang ditampilan perhalaman  if(isset($_GET['hal'])){ //jika terjadi get maka kondisinya akan berubah nilai get dikali jmlh banyak tampil, kalau ada 8 data kemudian dibagi empat maka derma data akan terbagi dua, 1x4=4, 2x4=8, begitupun kalau misal jumlah data ada 16, 1x4=4 2x4=8, 4x3=12, 4x4=16. melaluiataubersamaini catatan, nilai 1 berarti dihitung sebagai 0 dan nilai 2 yaitu 1, dan 3 yaitu 2, nilai get ini akan merubah nilai variabel $awal pada limit data. Kalau salah mohon luruskan... heheh     $awal=$_GET['hal']*$byk_tampil;  } $perintah="SELECT * FROM tpdb_daftar"; $limit="limit $awal,$byk_tampil"; //limit nilainya sesuai jumlah data yang ingin ditampilkan $per_limit=sprintf("%s %s",$perintah,$limit); $allquery=mysqli_query($koneksi, $perintah); //query utama tanpa melimit data $per_laman=mysqli_query($koneksi,$per_limit); //query ini jalan di fetch array dan dilimit $jumlah=mysqli_num_rows($allquery); //pake query utama untuk jumlahin data ?> <div id="wrapper"> <!-- Main --> <div id="main"> <div class="container"> <section> <header class="major"> <h2>Pengumuman</h2> <p>Siswa yang sudah mendaftar</p> </header> <p>Bila Anda sudah mendaftar namun status datanya masih belum diverifikasi, maka harap bersabar, sebab kemungkinan belum diverifikasi/diperiksa oleh Panitia PPDB</p> <div class="table-wrapper"> <table class="alt"> <tr> <td>No</td> <td>Nama Siswa</td> <td>Asal Sekolah</td> <td>Status Pendaftaran</td> <td>Print</td> </tr> <tbody> <?php //memulai penomoran/pengurutan data dari database, kalau $no diaktfikan menggantikan $id maka penomoran data akan dimulai dari angka 1 $no=$awal+1; //variabel $no yang berarti 0+1 //proses perulang dengan meilimit data sesuai dengan data yang ingin ditampilkan perhalaman while($data=mysqli_fetch_array($per_laman)){ ?> <tr> <td><?php echo $data['id'] ?></td> <td><?php echo $data['nama_siswa'];?></td> <td><?php echo $data['sekolah'];?></td> <td><?php echo $data['status_siswa'];?></td> <td> <a href="#" target=_"blank"><i class="fa fa-print fa-fw" alt=" Paging atau penomoran halaman yang Saya maksud disini yaitu Teknik Paging di PHP" title="Teknik Paging di PHP"></i></a></td> </tr> <?php $no+=1;} //selanjutnya berarti 0+1=1, nomor data dimulai dari 1 kalau engkau pake variabel $no ?> <tfoot> <tr> <td colspan="4">Jumlah Pendaftar Saat Ini</td> <td><?php echo $jumlah ?></td> </tr> </tfoot> </tbody> </table> <center> <?php //memulai pagging  $ke="pengumuman"; //ini ada pengaturan di httaccess, ini untuk urlnya, dapat saja nilainya meliputi $_GET['PHP_SELF'] $page=ceil($jumlah/4); //jumlah data dibagi, misal 8:8=1 berati jumlah data akan dibagi 8, ini untuk nomor halamannya, kalau misal ada 16 data kemudian dibagi 4, maka penomoran halamannya akan dibagi menjadi 4 penomoran, dimana nilai 1 akan dihitung sebagai 0, 2 sebagai 1 dan seterusnya $pg=1; //sekarang muali perulangan while($pg<=$page){ //jika $pg lebih kecil atau sama dengan $page 1=1, contohnya kondisi data disini yaitu 8 data terus dibagi 4 berarti nilai 2, nah kondisinya nanti berarti 1<=2 $hal=$pg-1; //maka $hal 1-1=0, kalau $hal=0 maka saat request/klik angka 1 di url akan terlihat menjadi data 0 echo " <a href=\"$ke?hal=$hal\">$pg</a>"; //disini akan dimulai request get //perulangan data akan dilakukan hingga kondisi terpenuhi, kalau misal kondisinya 8:4=2, maka 1<=2 dan data akan diulang hingga nilai 2, kalau misal jmlah datanya 16 maka 16:4=4, maka halaman akan bernilai 1:4, sehingga $pg+ akan diulang hingga 4 penomoran     $pg+=1;  } ?> <br/> Halaman :<?php echo" $hal dari $page";?><br/></center> </div> </section> </div> </div> <?php //footer include('system/inc/footer.php') ?> 


Bila berhasil, kurang lebih paging (penomoran halaman) akan terlihat menyerupai diberikut ini, misal.

 Paging atau penomoran halaman yang Saya maksud disini yaitu Teknik Paging di PHP

Post a Comment for "Teknik Paging Di Php"