CRUD PHP Ajax Dengan Modal Bootstrap

CRUD PHP Ajax Dengan Modal Bootstrap - root93


CRUD (Create, Read, Update, Delete) PHP Ajax Dengan Modal Bootstrap yang akan saya jelaskan ini kurang lebih memiliki alur seperti yang terlihat pada gambar diatas. Secara sederhana, pertama kita akan membuat semacam tombol atau link triger dari HTML ke Ajax, selanjutnya Ajax/Javascript akan melakukan request ke PHP, lalu jika request berhasil maka data bisa ditampilkan dalam bentuk tipe HMTL Data atau JSON didalam modal Bootstrap.

Pada tutorial CRUD PHP Ajax Dengan Modal Bootstrap ada beberapa hal yang akan dilakukan diantaranya :

1. Proses penambahan data didalam modal
2. Proses menampilkan data didalam modal
3. Proses update/edit data didalam modal
4. Proses delete data

Selanjutnya ada beberapa keunggulan dalam proses CRUD PHP Ajax Dengan Modal Bootstrap yang sederhana ini dibandingkan dengan proses crud yang hanya melibatkan html dan php saja.
  1. Proses CRUD bisa dilakukan tanpa berpindah – pindah halaman, sehingga proses penggunaannya memang terlihat lebih simpel
  2. Lebih interaktif karena ada efek animasi modal bootstrap
  3. Proses tambah, edit dan delete data terlihat lebih cepat seperti tanpa loading saat submit data

CRUD PHP Ajax di Dalam Modal Bootstrap
Ada beberapa file yang perlu dibuat, saya akan memisah – misah file tersebut sesuai dengan fungsinya supaya lebih mudah. Struktur filenya akan dibuat seperti berikut
File CRUD PHP Ajax Dengan Modal Bootstrap - root93


Database
CREATE TABLE `datamhs` (
  `id` int(13) NOT NULL,
  `nim` varchar(30) NOT NULL,
  `nama_mahasiswa` varchar(30) NOT NULL,
  `foto_mahasiswa` varchar(30) NOT NULL,
  `tanggal_daftar` timestamp NOT NULL DEFAULT CURRENT_TIMESTAMP ON UPDATE CURRENT_TIMESTAMP
) ENGINE=InnoDB DEFAULT CHARSET=latin1;

--
-- Dumping data untuk tabel `datamhs`
--

INSERT INTO `datamhs` (`id`, `nim`, `nama_mahasiswa`, `foto_mahasiswa`, `tanggal_daftar`) VALUES
(1, '1023564', 'Ahmad Zaelani', '', '2019-08-15 06:01:28'),
(2, '1478523', 'Noni Indriawati', '', '2019-08-15 06:01:20'),
(3, '1023589', 'Firman Alamsyah', '', '2019-08-15 06:01:42'),
(4, '1369875', 'Susi Susanti', '', '2019-08-15 06:01:54');

--
-- Indexes for dumped tables
--

--
-- Indexes for table `datamhs`
--
ALTER TABLE `datamhs`
  ADD PRIMARY KEY (`id`);

--
-- AUTO_INCREMENT for dumped tables
--

--
-- AUTO_INCREMENT for table `datamhs`
--
ALTER TABLE `datamhs`
  MODIFY `id` int(13) NOT NULL AUTO_INCREMENT, AUTO_INCREMENT=5;
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */;
/*!40101 SET CHARACTER_SET_RESULTS=@OLD_CHARACTER_SET_RESULTS */;
/*!40101 SET COLLATION_CONNECTION=@OLD_COLLATION_CONNECTION */;

A_css.php
File ini nantinya bisa kalian isi dengan cdn/lokal file css bootrap dan fontawesome

<link href="lib/bootstrap/css/bootstrap.min.css" rel="stylesheet">
<link href="lib/fontawesome-free/css/all.min.css" rel="stylesheet">
</head>
<body>
 <div class="container" style="width: 700px">


A_footer.php
File ini bisa di isi oleh link cdn/lokal file javascript jquery, bootstrap, dan modal js yang berisi request ke php

<!--Container div akhir -->
</div>
<!--Bootstrap Core -->
<script src="lib/jquery/jquery.min.js"></script>
<script src="lib/bootstrap/js/bootstrap.min.js"></script>
<!--Bagian Js Modal Triger Untuk -->
<script src="lib/modal-triger/modal.js"></script>
</body>
</html>


A_head.php

<html>
<head>
<title>MAHASISWA ROOT93</title>


ajax.delete.php
Untuk fungsi delete disini masih belum menggunakan modal, tapi menggunakan alert javascript biasa, untuk membuat konfirmasi delete data menggunakan modal Anda bisa membaca tutorial : Membuat Konfirmasi Delete Data Menggunakan Modal Bootstrap

<?php
include ('koneksi.php');
include ('function.php');
?>
<?php
if(isset($_POST['delete_id'])){
 if(delete_data($_POST['delete_id'])){
 echo "<p style='color: red;'>Data berhasil dihapus</p>";
        $result = tampil_data();
        if($result){      
        echo "<table width='100%' class='table table-striped table-bordered table-hover'>";
        echo "<tr>";
    
        echo "<th>NIM</th>";
        echo "<th>NAMA MAHASISWA</th>";
                
        echo "<th>AKSI</th>";
        echo "</tr>";      
        while($row=mysqli_fetch_array($result)){
        echo "<tr>";

        echo "<td>".$row['nim']."</td>";        
        echo "<td>".$row['nama_mahasiswa']."</td>";     
        echo "<td>";
        echo "<a href='#' name='delete' id='".$row['id']."; ?>' class='delete_data'><i class='fa fa-trash fa-fw small' alt='delete' title='delete'></i></a>";

        echo "<a href='#' data-target='#confirm-detail' id='".$row['id']."; ?>' class='lihat_data'><i class='fa fa-eye fa-fw small' alt='detail' title='detail'></i></a>";
        
      echo "<a href='#' name='update' id='".$row['id']."; ?>' class='update_data'><i class='fa fa-edit fa-fw small' alt='edit' title='edit'></i></a>";

        echo "</td>";
        echo "</tr>";
        }
        echo "</table>";
         mysqli_free_result($result);   
    
        }    
 }else{
  die("error");
 }
        mysqli_close($koneksi);

}
?>


ajax.detail.php


<?php
include ('koneksi.php');
include ('function.php');  
 if(isset($_POST["detail_mahasiswa"])){
 if(!detail_data(trim($_POST["detail_mahasiswa"]))){
    die("error");
 }

 }else{
    die("error");
 }  
       
      echo "<div class='table-responsive'>";  
      echo "<table width='100%' class='table table-striped table-bordered table-hover'>";  
     
       
                echo "<tr>";  
                echo "<td>ID</td>";  
                echo  "<td>".$id."</td>";  
                echo "</tr>";  
                echo "<tr>";  
                echo "<td>NIM</td>";  
                echo  "<td>".$nim."</td>";  
                echo "</tr>";  
                echo "<tr>";  
                echo "<td>Nama Mahasiswa</td>";  
                echo  "<td>".$nama_mahasiswa."</td>";  
                echo "</tr>";
                echo "<tr>";  
                echo "<td>Tanggal Daftar/Edit</td>";  
                echo  "<td>".$tanggal_daftar."</td>";  
                echo "</tr>";
                
       
      echo "</table>";
      echo "</div>";  
     
 
 ?>


ajax.edit.php

<?php

include ('koneksi.php');
include ('function.php');
?>

<?php
if(isset($_POST["update_id"])){

 if(!detail_data(trim($_POST['update_id']))){  
  die ("Data tidak ditemukan");
 }
}

//Merubah variabel dari bind result ke json, disimpan ke array terlebih dahulu
$array=array(
 0=>"$id",'id'=>"$id",
 1=>"$nim",'nim'=>"$nim",
 2=>"$nama_mahasiswa",'nama_mahasiswa'=>"$nama_mahasiswa"
 

);
echo json_encode($array);
?> 
   


ajax.edit.proses.php


<?php
include ('koneksi.php');
include ('function.php');
?>
<?php

if(isset($_POST["update_id"])){
if($_SERVER["REQUEST_METHOD"]=="POST"){
    if(empty($_POST['update_id'])){
    $id_err="id masih ksong";
    }else{
    $id=$_POST['update_id'];
    $id=mysqli_real_escape_string($koneksi, $id);
    }
    if(empty(trim($_POST['nim']))){
    $nim_err = "Nim tidak boleh kosong";
    }else{
    $nim=$_POST['nim'];
    $nim=mysqli_real_escape_string($koneksi, $nim);
    }    
    if(empty(trim($_POST['nama_mahasiswa']))){
    $nama_mahasiswa_err = "Nama mahasiswa tidak boleh kosong";
    }else{
    $nama_mahasiswa = $_POST['nama_mahasiswa'];
    $nama_mahasiswa = mysqli_real_escape_string($koneksi, $nama_mahasiswa);
    }
 
   
if(empty($nim_err) && empty($nama_mahasiswa_err) && empty($id_err)){
        if(update_mahasiswa($id, $nim, $nama_mahasiswa)){
       echo "<p style='color: red;'>Berhasil mengupdate data</p>";
        $result = tampil_data();        
        if($result){      
        echo "<table width='100%' class='table table-striped table-bordered table-hover'>";
        echo "<tr>";
    
        echo "<th>NIM</th>";
        echo "<th>NAMA MAHASISWA</th>";
                
        echo "<th>AKSI</th>";
        echo "</tr>";
        //loping data
        while($row=mysqli_fetch_array($result)){
        echo "<tr>";

        echo "<td>".$row['nim']."</td>";        
        echo "<td>".$row['nama_mahasiswa']."</td>";     
        echo "<td>";
        echo "<a href='#' name='delete' id='".$row['id']."; ?>' class='delete_data'><i class='fa fa-trash fa-fw small' alt='delete' title='delete'></i></a>";

        echo "<a href='#' data-target='#confirm-detail' id='".$row['id']."; ?>' class='lihat_data'><i class='fa fa-eye fa-fw small' alt='detail' title='detail'></i></a>";
        
        echo "<a href='#' name='update' id='".$row['id']."; ?>' class='update_data'><i class='fa fa-edit fa-fw small' alt='edit' title='edit'></i></a>";

        echo "</td>";
        echo "</tr>";
        }
        echo "</table>";
       
        //free result
        mysqli_free_result($result);   
    
        }
    }else{
    echo 'Gagal menyimpan data';
    }
     
      
    }
        mysqli_close($koneksi);
    }
}

?>


ajax.input.php

<?php
include ('koneksi.php');
include ('function.php');
?>
<?php
if(isset($_POST["mahasiswa_id"])){
    if(empty(trim($_POST['nim']))){
        $nim_err = "Nim tidak boleh kosong";
        }else{
            
            $nim=$_POST['nim'];
            $nim=mysqli_real_escape_string($koneksi, $nim);
   
        }    
        if(empty(trim($_POST['nama_mahasiswa']))){
            $nama_mahasiswa_err = "Nama mahasiswa tidak boleh kosong";
            }else{
            $nama_mahasiswa = $_POST['nama_mahasiswa'];
            $nama_mahasiswa = mysqli_real_escape_string($koneksi, $nama_mahasiswa);
        }
        
//cek input sebelum insert untuk memastikan tidak ada data yang error
    if(empty($nim_err) && empty($nama_mahasiswa_err)){
        if(simpan_mahasiswa($nim, $nama_mahasiswa)){
       echo "<p style='color: red;'>Berhasil menyimpan data</p>";
        $result = tampil_data();        
        if($result){      
        echo "<table width='100%' class='table table-striped table-bordered table-hover'>";
        echo "<tr>";
    
        echo "<th>NIM</th>";
        echo "<th>NAMA MAHASISWA</th>";
                
        echo "<th>AKSI</th>";
        echo "</tr>";
        //loping data
        while($row=mysqli_fetch_array($result)){
        echo "<tr>";

        echo "<td>".$row['nim']."</td>";        
        echo "<td>".$row['nama_mahasiswa']."</td>";     
        echo "<td>";
        echo "<a href='#' name='delete' id='".$row['id']."; ?>' class='delete_data'><i class='fa fa-trash fa-fw small' alt='delete' title='delete'></i></a>";

        echo "<a href='#' data-target='#confirm-detail' id='".$row['id']."; ?>' class='lihat_data'><i class='fa fa-eye fa-fw small' alt='detail' title='detail'></i></a>";
        
        echo "<a href='#' name='update' id='".$row['id']."; ?>' class='update_data'><i class='fa fa-edit fa-fw small' alt='edit' title='edit'></i></a>";

        echo "</td>";
        echo "</tr>";
        }
        echo "</table>";
       
        //free result
        mysqli_free_result($result);   
    
        }
    }else{
    echo 'Gagal menyimpan data';
    }
     
      
        }
        mysqli_close($koneksi);
  
    }

?>



function.php
File ini berisi operasi atau function untuk menyimpan, menampilkan, menambah dan menedelete data. Proses query yang dilakukan juga mengggunakan prepared statement. Baca : CRUD PHP Procedural Style

<?php
function prepare($data){
 global $koneksi;
 $perintah=mysqli_prepare($koneksi,$data);
 if(!$perintah) die("Gagal melakukan koneksi".mysqli_error($koneksi));
 return $perintah;
}
function query($data){
 global $koneksi;
 $perintah=mysqli_query($koneksi, $data);
 if(!$perintah) die("Gagal melakukan koneksi".mysqli_error($koneksi));
 return $perintah;
}
function execute($data){
 $perintah=mysqli_stmt_execute($data);
 return $data;
}
function stmt_close($data){
 $perintah=mysqli_stmt_close($data);
 return $data;
}

function simpan_mahasiswa($nim, $nama_mahasiswa){
   
    $sql="INSERT INTO datamhs(nim, nama_mahasiswa) VALUES (?,?)";
    if($stmt=prepare($sql)){
        mysqli_stmt_bind_param($stmt,"ss",$param_nim, $param_nama_mahasiswa);
        $param_nim = $nim;
        $param_nama_mahasiswa = $nama_mahasiswa;

    if(execute($stmt)){
      return true;
   }else{
      return false;
   }

 
 }
 stmt_close($stmt);
}

function tampil_data(){
 $sql="SELECT id, nim, nama_mahasiswa, foto_mahasiswa, tanggal_daftar FROM datamhs";
 $result=query($sql);
 return $result;
}


function delete_data($var_id){
 global $koneksi;
 $sql = "DELETE FROM datamhs where id =?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"i", $param_id);
  $param_id = $var_id;
  
  if(mysqli_stmt_execute($stmt)){
   return true;
  }else{
   return false;
  }
 }
 
 
}


function detail_data($var_id){
 global $koneksi;
 global $id, $nim, $nama_mahasiswa, $tanggal_daftar;
 $sql="SELECT id, nim, nama_mahasiswa, tanggal_daftar FROM datamhs WHERE id=?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"i",$param_id);
  $param_id = $var_id;
  if(mysqli_stmt_execute($stmt)){
   mysqli_stmt_store_result($stmt);
   mysqli_stmt_bind_result($stmt, $id, $nim, $nama_mahasiswa, $tanggal_daftar);
   mysqli_stmt_fetch($stmt);
   if(mysqli_stmt_num_rows($stmt)==1){
    return true; //jika ada data nilai true
   }else{
    return false; //jika data tidak ditemukan nilai false
   }
  }else{
   echo "Terjadi kesalahan";
  }
 }
 stmt_close($stmt);
}

function update_mahasiswa($id, $nim, $nama_mahasiswa){
 global $koneksi;
 $sql ="UPDATE datamhs SET nim=?, nama_mahasiswa=? WHERE id=?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"ssi",$param_nim, $param_nama_mahasiswa, $param_id);
  //set parameter
  $param_id = $id;
  $param_nim = $nim;
  $param_nama_mahasiswa = $nama_mahasiswa;
  
      if(mysqli_stmt_execute($stmt)){
       return true;
    }else{
       return false;
    }
     

 }
}
function cek_nim($data){
 global $koneksi;
 $sql = "SELECT nim FROM datamhs WHERE nim=?";
 if($stmt=mysqli_prepare($koneksi, $sql)){
  mysqli_stmt_bind_param($stmt,"s", $param_nim);
  $param_nim=$data;
  if(mysqli_stmt_execute($stmt)){
   mysqli_stmt_store_result($stmt);
   if(mysqli_stmt_num_rows($stmt)==1){
    $simpan=true;
   }else{
    $simpan=false;
   }
   return $simpan;
  }else{
   die("Error");
  }
 }
 mysqli_stmt_close($stmt);
}
?>



index.php

<?php
include ('koneksi.php');
include ('function.php');
include('A_head.php');
include('A_css.php');

?>
<br /><br /> 
 <div align="right" style="color: red;">  
  <button type="button" name="add" id="add" data-toggle="modal" data-target="#add_data_Modal" class="btn btn-warning">Add</button>  
  </div> 
 <br /><br /> 
 <h3 align="center">CRUD PHP Ajax Dengan Modal Bootstrap - R93 :)</h3>

<?php
//memanggi function
$result = tampil_data();
  //mengeksekusi function didalam percabangan
  if($result){
  
  echo "<div id='tabel_mahasiswa'>";
  echo "<table width='100%' class='table table-striped table-bordered table-hover'>";
  echo "<tr>";
 
  echo "<th>NIM</th>";
  echo "<th>NAMA MAHASISWA</th>";
    
  echo "<th>AKSI</th>";
  echo "</tr>";
  //loping data
  while($row=mysqli_fetch_array($result)){
  echo "<tr>";

  echo "<td>".$row['nim']."</td>";  
  echo "<td>".$row['nama_mahasiswa']."</td>";  
  echo "<td>";
  echo "<a href='#' name='delete' id='".$row['id']."; ?>' class='delete_data'><i class='fa fa-trash fa-fw small' alt='delete' title='delete'></i></a>";

  echo "<a href='#' data-target='#confirm-detail' id='".$row['id']."; ?>' class='lihat_data'><i class='fa fa-eye fa-fw small' alt='detail' title='detail'></i></a>";
  
  echo "<a href='#' name='update' id='".$row['id']."; ?>' class='update_data'><i class='fa fa-edit fa-fw small' alt='edit' title='edit'></i></a>";

  echo "</td>";
  echo "</tr>";
  }
  echo "</table>";
  echo "</div>";
  //free result
  mysqli_free_result($result);

 
 
 }



?>

<?php include('modal.php'); ?>
<?php include('A_footer.php'); ?>


koneksi.php


<?php
define('DB_SERVER','localhost');
define('DB_USERNAME','root');
define('DB_PASSWORD', '');
define('DB_NAME','datamhs');
$koneksi = mysqli_connect(DB_SERVER, DB_USERNAME, DB_PASSWORD, DB_NAME);
if($koneksi == false){
 die ("Gagal melakukan koneksi ke database.".mysqli_connect_error());
}
?>


modal.php
File modal.php ini nantinya bertugas untuk menambah, menampilkan atau mengupdate data


    <!-- Modal Tambah -->
    <div class="modal fade" id="add_data_Modal" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <h5 class="modal-title" id="exampleModalLabel">Tambah Data</h5>
            <button class="close" type="button" data-dismiss="modal" aria-label="Close">
              <span aria-hidden="true">×</span>
            </button>
          </div>
           
          <div class="modal-body">
           <form method="post" id="insert_form"/>
            <div class="form-group">
              <label>NIM :</label>
              <input type="text" name="nim" id="nim" class="form-control" />
            </div>
            <div class="form-group">
              <label>Nama Mahasiswa :</label>
              <input type="text" name="nama_mahasiswa" id="nama_mahasiswa" class="form-control" />
            </div>
            
            <input type="hidden" name="mahasiswa_id" id="mahasiswa_id" />  
            <input type="submit" name="insert" id="insert" value="Insert" class="btn btn-success" /> 
            </form>                   
          </div>        
          <div class="modal-footer">
            <button class="btn btn-secondary" type="button" data-dismiss="modal">Tidak</button>          
          </div>   
        </div>
      </div>
    </div>
     <!-- Modal Edit Update -->
    <div class="modal fade" id="update_data" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <h5 class="modal-title" id="exampleModalLabel">Update Data</h5>
            <button class="close" type="button" data-dismiss="modal" aria-label="Close">
              <span aria-hidden="true">×</span>
            </button>
          </div>
           
          <div class="modal-body">
           <form method="post" id="update_form" />
            <div class="form-group">
              <label>NIM :</label>
              <input type="text" name="nim" id="nim_m" class="form-control" />
            </div>
            <div class="form-group">
              <label>Nama Mahasiswa :</label>
              <input type="text" name="nama_mahasiswa" id="nama_mahasiswa_m" class="form-control" />
            </div>
            <input type="hidden" name="update_id" id="update_id_m" />  
            <input type="submit" name="update" id="update" value="Update" class="btn btn-success" /> 
            </form>                   
          </div>        
          <div class="modal-footer">
            <button class="btn btn-secondary" type="button" data-dismiss="modal">Tidak</button>          
          </div>   
        </div>
      </div>
    </div>
    <!-- Modal detail -->
    <div class="modal fade" id="confirm-detail" tabindex="-1" role="dialog" aria-labelledby="exampleModalLabel" aria-hidden="true">
      <div class="modal-dialog" role="document">
        <div class="modal-content">
          <div class="modal-header">
            <h5 class="modal-title" id="exampleModalLabel">Detail Data</h5>
            <button class="close" type="button" data-dismiss="modal" aria-label="Close">
              <span aria-hidden="true">×</span>
            </button>
          </div>
          <div class="modal-body" id="detail_mahasiswa">
          </div>
          <div class="modal-footer">
            <button class="btn btn-secondary" type="button" data-dismiss="modal">Tutup</button>
                    
          </div>      
        </div>
      </div>
    </div>
    


modal.js
File javascript ini nantinya akan bertugas untuk melakukan request/submit data ke php


$(document).ready(function(){  
      $('#add').click(function(){  
           $('#insert').val("Insert");  
           $('#insert_form')[0].reset();  
      });



$(document).on('click', '.update_data', function(){  
           var update_id = $(this).attr("id");  
           $.ajax({  
                url:"ajax.edit.php",  
                method:"post",  
                data:{update_id:update_id},  
                dataType:"json",  
                success:function(data){  
                     $('#nim_m').val(data.nim);  
                     $('#nama_mahasiswa_m').val(data.nama_mahasiswa); 
                     $('#update_id_m').val(data.id);  
                     $('#update').val("update");  
                     $('#update_data').modal('show');  
                }  
           });  
      });
$('#update_form').on("submit", function(event){  
           event.preventDefault();  
           if($('#nim_m').val() == "")  
           {  
                alert("NIM Mahasiswa Harus Di isi");  
           }  
           else if($('#nama_mahasiswa_m').val() == "")  
           {  
                alert("Nama Mahasiswa harus di isi");  
           }  
           
           else  
           {  
                $.ajax({  
                     url:"ajax.edit.proses.php",  
                     method:"POST",
                     data:$('#update_form').serialize(),  
                     beforeSend:function(){  
                          $('#update').val("Updating");  
                     },  
                     success:function(data){  
                          $('#update_form')[0].reset();  
                          $('#update_data').modal('hide');  
                          $('#tabel_mahasiswa').html(data);  
                     }  
                });  
           }  
      });
 
 $('#insert_form').on("submit", function(event){  
           event.preventDefault();  
           if($('#nim').val() == "")  
           {  
                alert("NIM Mahasiswa Harus Di isi");  
           }  
           else if($('#nama_mahasiswa').val() == "")  
           {  
                alert("Nama Mahasiswa harus di isi");  
           }  
           
           else  
           {  
                $.ajax({  
                     url:"ajax.input.php",  
                     method:"POST",
                     data:$('#insert_form').serialize(),  
                     beforeSend:function(){  
                          $('#insert').val("Inserting");  
                     },  
                     success:function(data){  
                          $('#insert_form')[0].reset();  
                          $('#add_data_Modal').modal('hide');  
                          $('#tabel_mahasiswa').html(data);  
                     }  
                });  
           }  
      });

    $(document).on('click', '.delete_data', function(){  
           var delete_id = $(this).attr("id");
           if(confirm("Are you sure to delete this category")){
            
           $.ajax({  
                url:"ajax.delete.php",  
                method:"post",  
                data:{delete_id:delete_id},
                success:function(data){                    
                    $('#tabel_mahasiswa').html(data);   
                }  
           });
           }  
      });


   $(document).on('click', '.lihat_data', function(){  
           var detail_mahasiswa = $(this).attr("id");  
           $.ajax({  
                url:"ajax.detail.php",  
                method:"post",  
                data:{detail_mahasiswa:detail_mahasiswa},  
                success:function(data){  
                     $('#detail_mahasiswa').html(data);  
                     $('#confirm-detail').modal("show");  
               }  
                });  
           });            
  });  
 

Live Demo / Penjelasan


1 Response to "CRUD PHP Ajax Dengan Modal Bootstrap"

  1. Mantab
    Sy tak numpang menyerap ilmunya dulu om

    ReplyDelete

Komentar yang Anda kirim akan terlebih dahulu di moderasi oleh Admin

Virgobet88lotre4dBandar Lotre4DGama69RajajagoGama69GAMA69RajaJagohttps://linkr.bio/gama69https://mez.ink/rajajagohokiToto Slot 4D Lotre4DLotre4D Onlinevirgobet88 daftarRajajago GameVirgobet88Slot Virgobet88Linkr Virgobet88Virgobet88strategi harian mahjong ways untuk menentukan waktu emas spin dengan akurasi tinggipanduan mahjong ways membaca pola spin dan keberuntungan berdasarkan ritme harianteknik pro mahjong ways mengelola spin beruntun agar peluang jackpot lebih besarhasil analisis mahjong ways terkait ritme dan tempo spin yang paling efektifrahasia mahjong ways menyesuaikan kecepatan spin untuk hasil stabil dan menguntungkanstrategi pemain berpengalaman menentukan ritme spin berdasarkan waktu hokipola spin harian yang sering digunakan pemain pro untuk meningkatkan peluangpanduan membaca perubahan tempo spin agar lebih konsisten dalam bermainhasil riset terbaru tentang ritme spin dan korelasi keberuntungan pemainteknik pro menentukan jadwal spin harian yang paling efektif untuk stabilitasstrategi harian pemain pro menentukan waktu spin berdasarkan perubahan keberuntunganpanduan membaca ritme dan tempo spin untuk meningkatkan peluang jackpotteknik pemain berpengalaman mengatur kecepatan spin dan menentukan jam hokihasil analisis spin harian berdasarkan pola ritme dan frekuensi kemenanganrahasia pemain pro dalam menentukan momen emas spin yang paling efektifvirgobet88 bagikan strategi spin terbaru dengan analisis waktu hoki yang terbuktitips efektif dari virgobet88 untuk membaca pola spin dan perubahan keberuntunganvirgobet88 ungkap rahasia spin harian berdasarkan data dan kebiasaan pemainpanduan virgobet88 menentukan ritme spin yang konsisten untuk hasil stabilstrategi hoki virgobet88 memanfaatkan waktu tepat spin dan kecepatan bermainstrategi harian pemain pro menentukan pola spin berdasarkan ritme dan keberuntunganpanduan efektif membaca waktu emas spin agar peluang kemenangan meningkathasil penelitian tentang ritme dan tempo spin yang mempengaruhi peluang jackpotrahasia pemain berpengalaman memanfaatkan perubahan tempo spin untuk hasil stabilteknik pro menentukan jam hoki spin dan pola beruntun yang paling efektifstrategi harian mahjong ways dalam memanfaatkan ritme spin dan perubahan keberuntunganpanduan mahjong ways menentukan waktu hoki spin agar peluang jackpot meningkatanalisis mahjong ways terkait tempo spin dan konsistensi kemenangan pemainrahasia pro mahjong ways dalam mengatur spin beruntun dan kecepatan hariantips efektif mahjong ways menyesuaikan ritme dan frekuensi spin untuk hasil optimalstrategi harian pemain pro memanfaatkan ritme dan frekuensi spin untuk meningkatkan bonuspola spin efektif yang digunakan pemain berpengalaman saat perubahan tempo hariananalisis waktu hoki dalam menentukan momen tepat spin agar keuntungan maksimalteknik berlapis spin harian untuk membangun pola beruntun dan peluang jackpotrahasia pemain berhasil mengatur kecepatan spin dan menang lebih konsistenpetimas88 ungkap strategi berlapis spin dan pola hoki untuk bonus lebih seringpetimas88 bagikan cara menentukan jam emas spin agar peluang kemenangan meningkatpetimas88 analisis pola spin harian yang sering memberi keuntungan besarteknik spin pro dari petimas88 dalam mengelola tempo dan frekuensi bermainpetimas88 tips mengatur ritme spin dan meningkatkan stabilitas kemenanganstrategi pemain pro membaca ritme dan waktu emas spin agar peluang bonus naik drastisanalisis ritme spin harian dan cara menentukan momen hoki untuk kemenangan stabilpanduan lengkap mengenali pola spin berirama yang sering munculkan bonus besarrahasia waktu hoki dalam spin harian yang sering digunakan pemain berpengalamantips membaca pola dan kecepatan spin agar tidak kehilangan peluang jackpotstrategi spin mahjong ways membaca perubahan tempo dan menang lebih konsistenpanduan mahjong ways menentukan jam emas spin dan meningkatkan hoki harianteknik pemain pro mahjong ways mengatur ritme spin untuk hasil lebih stabilanalisis mahjong ways terhadap pola spin berlapis yang bisa bikin peluang jackpot naikrahasia mahjong ways memanfaatkan perubahan tempo spin dalam mencapai maxwinstrategi spin harian memanfaatkan ritme dan waktu hoki untuk peluang bonus lebih besarrahasia pemain pro menentukan tempo spin yang sering munculkan kemenangan beruntunpanduan lengkap memilih waktu emas spin agar peluang menang naik drastisanalisis perubahan ritme spin dan pengaruhnya terhadap hasil kemenangan hariantrik pemain berpengalaman mengatur kecepatan spin demi hasil stabil dan menguntungkanstrategi mahjong ways mengatur tempo dan waktu spin untuk meningkatkan keberuntunganpanduan pro mahjong ways membaca pola dan kecepatan spin agar peluang jackpot lebih besaranalisis pola spin mahjong ways dalam menentukan momen emas untuk menang konsistenrahasia mahjong ways memanfaatkan ritme harian spin dan perubahan keberuntunganteknik efektif mahjong ways menyesuaikan kecepatan spin untuk mendapatkan maxwinpanduan membaca ritme dan frekuensi spin harian untuk meningkatkan peluang jackpotstrategi pemain pro menentukan tempo spin harian dan waktu hoki paling menguntungkananalisis ritme spin berdasarkan perubahan keberuntungan dan pola pergerakan hariantrik mengatur kecepatan spin demi kemenangan stabil dalam sesi bermain harianrahasia pemain berhasil menemukan pola spin harian yang sering memberi hasil positifvirgobet88 ungkap hasil analisis ritme spin harian yang berpengaruh pada peluang maxwinstrategi virgobet88 memanfaatkan frekuensi dan ritme spin untuk meningkatkan peluang kemenanganvirgobet88 bagikan teknik mengatur tempo spin dan waktu emas agar hasil lebih stabilhasil riset virgobet88 tentang perubahan ritme spin dan pengaruhnya terhadap keberuntunganpanduan virgobet88 menentukan ritme dan frekuensi spin optimal untuk hasil maksimalstrategi pemain pro membaca pola spin berdasarkan ritme dan waktu hariananalisis ritme spin dan frekuensi keberuntungan yang sering digunakan pemain ahlipanduan mengenali waktu emas spin dan momen hoki dalam setiap permainanrahasia pola spin harian yang mampu meningkatkan kesempatan jackpot besartips mengatur tempo dan kecepatan spin agar keberuntungan lebih stabilstrategi mahjong ways memanfaatkan ritme dan perubahan spin untuk peluang maksimalrahasia pemain pro mahjong ways menentukan waktu hoki dari pola ritme hariananalisis mahjong ways terkait pola dan frekuensi spin beruntun yang menguntungkanpanduan harian mahjong ways menyesuaikan tempo spin dengan perubahan keberuntungantips pro mahjong ways mengatur ritme spin dan membaca pola hoki setiap sesistrategi pemain pro membaca pola spin harian untuk memaksimalkan keberuntungananalisis ritme dan frekuensi spin yang sering dipakai pemain ahli untuk jackpotrahasia spin berirama dan pengaturan tempo yang efektif untuk hasil stabilpanduan harian memanfaatkan waktu emas spin dalam meningkatkan peluang menangtips pemain berpengalaman menentukan jam hoki dan tempo spin paling menguntungkanpetimas88 bagikan strategi spin harian dengan pola dan ritme beruntun yang terujiteknik petimas88 menentukan perubahan tempo spin untuk hasil lebih menguntungkanpetimas88 ungkap rahasia pola spin berirama yang sering berbuah kemenangan besarpanduan lengkap petimas88 membaca perubahan spin harian berdasarkan data keberuntunganpetimas88 strategi bermain dengan analisis ritme spin dan pola keberuntungan terbaruanalisis pola ritme spin malam hari yang sering dipakai pemain untuk menang besarstrategi pemain pro memanfaatkan jam hoki malam untuk peluang jackpot lebih tinggistudi terbaru tentang pengaruh tempo spin malam terhadap tingkat kemenanganpanduan harian mengenali waktu emas spin pada malam hari agar lebih menguntungkanrahasia pemain berpengalaman mengelola spin malam dengan pola beruntun efektifstrategi spin mahjong ways di malam hari yang sering menghasilkan keberuntungan besarpanduan membaca pola mahjong ways malam hari untuk meningkatkan peluang jphasil observasi pemain pro terhadap ritme spin mahjong ways di jam hokianalisis waktu terbaik spin mahjong ways malam hari berdasarkan data pemain berhasilrahasia pola mahjong ways malam hari yang sering memicu kemenangan beruntunfreelancer canva dapat bonus harian berkat tips bermain mahjong ways 3 konsistenibu laundry medan cuan dari scatter spiral mahjong ways 2 di jam 10 pagipenjual nasi kuning cuan lewat tips bermain turbo spiral mahjong ways 3 manualibu warung di sidoarjo menang game lewat kombinasi spiral spiral di mahjong ways 2tukang cukur pakai mahjong ways 2 dan dapat rp1 1 juta dari spiral manual 5xpenjual tahu gejrot main spiral turbo jam 7 pagi lewat mahjong ways 3 manualmahasiswi manajemen sukses ulang pola spin turbo mahjong ways 2 untuk bonusmahasiswi psikologi pakai scatter jam 9 di mahjong ways 3 dan balik modal cepatpegawai fotokopi di depok main mahjong ways 2 dan menang lewat pola spiral lamapenjaga minimarket menang game setelah coba tips bermain mahjong ways 3mahasiswa teknik industri bongkar cara menang spiral spiral mahjong ways 2 manualpenjual kue lapis dapat rp1 2 juta karena pola spin turbo pagi mahjong ways 3mahasiswa arsitektur dapat rp1 4 juta dari kombinasi scatter mahjong ways 2 subuhibu rumah tangga di cimahi menang game karena turbo spiral mahjong ways 3 jam 6mahasiswi ilmu komunikasi ungkap pola spin rahasia mahjong ways 3 hari rabupenjual lontong sayur dapat tambahan dari mahjong ways 3 berkat scatter subuhsupir ojek online palembang menang game karena scatter spiral mahjong ways 2freelancer jasa posting sosmed cuan lewat tips bermain mahjong ways 2 jam pagisupir pangkalan cuan karena spin turbo 3 detik mahjong ways 3 konsistenmahasiswa desain produk pakai mahjong ways 2 untuk menang lewat scatter delaymahasiswa informatika coba spiral ganjil genap dan cuan dari mahjong ways 2penjaga toko bangunan menang game setelah coba pola spiral turbo mahjong ways 3supir truk banjarmasin dapat rp1 juta dari spiral spiral mahjong ways 2 hari libursupir angkot bekasi main scatter ganjil genap dan menang mahjong ways 2 jam subuhpenjual es teh manis menang game karena spiral mahjong ways 3 delay pola ganjilsupir truk antar kota pakai mahjong ways 2 untuk menang game lewat scatter spiralpenjual bakso di solo ungkap cara menang spiral spiral mahjong ways 3 tanpa resetibu warteg jakarta cuan dari pola spiral mahjong ways 3 setiap hari seninpenjual sate klathak di jogja menang game karena pola spin turbo mahjong ways 3ibu penjual bubur ayam dapat tambahan uang dari spiral spiral mahjong ways 2Lucky Neko Gama69
analisis nilai mahjong ways untuk peningkatan disiplin kerjaimplementasi mahjong ways dalam dunia bisnis modernimplementasi filosofi mahjong ways dalam pelatihan layanan publikmahasiswa ekonomi belajar strategi bisnis dari mahjong waysnilai edukatif mahjong ways bagi pekerja sosialnilai edukatif mahjong ways untuk profesi arsitek mudanilai filosofi mahjong ways untuk profesi penelitinilai filosofis mahjong ways pada pendidikan guru paudnilai ketelitian mahjong ways untuk profesi editor bukunilai kesabaran dalam mahjong ways bagi profesi sopir angkotcara baru mudah menang pahami pola rtp ini dan rahasia orang dalamcara menang efektif dengan pola menang yang dibocorkan pragmaticcara menang pakai pola menang ampuh bocoran orang dalam pgsoftpahami pola rtp ini untuk cara menang berdasarkan bocoran pragmaticpola menang rahasia cara menang mudah ternyata ini caranyaternyata ini caranya trik menang paling mudah dari orang dalam pgsofttrik menang dari bocoran orang dalam pgsoft ternyata ini caranyatrik menang pahami pola rtp ini cara baru mudah menangtrik menang pahami pola rtp ini ternyata ini caranya dari orang dalam pragmaticpola menang rahasia cara menang mudah ternyata ini caranya