Tutorial CRUD Vue dan PHP Part 3: Update Data ke MySQL

Share:
Tutorial CRUD Vue dan PHP Part 3: Update Data ke MySQL
Halo semuanya, kembali lagi di sahretech. Kali ini kita akan belajar cara update data ke dalam database dengan vue js dan php, yang mana tutorial kali ini adalah tutorial lanjutan dari part sebelumnya. Ayo ikuti tutorialnya di bawah ini.



Cara Update Data dengan Vue ke MySQL

1. Buka file index.html di dalam file latihan-crud-vue-php sebelumnya. Cari script button edit lalu edit dengan script di bawah ini.
    

<!-- cari script button di bawah ini --> <button class="btn btn-sm btn-success">Edit</button> <!-- lalu edit menjadi di bawah ini --> <button class="btn btn-sm btn-success" data-bs-toggle="modal" data-bs-target="#modaledit" @click="editData(item.id, item.first_name, item.last_name)">Edit</button>


2.
Lalu copy script di bawah ini dan paste di bawah tulisan <-- di bawah ini adalah modal edit -->
      
    
<div class="modal fade" id="modaledit" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="exampleModalLabel">Form Edit</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> <input type="hidden" id="id" v-model="id"> <div class="form-group mb-2"> <label for="">Nama Depan</label> <input type="text" class="form-control" v-model="first_name"> </div> <div class="form-group"> <label for="">Nama Belakang</label> <input type="text" class="form-control" v-model="last_name"> </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> <button class="btn btn-primary" @click="updateData">Kirim</button> </div> </div> </div> </div>


3.
Copy script di bawah ini dan paste di bawah simpanData: function() {…}.
    

    //isi form saat modal edit tampil     editData: function(id, first_name, last_name){ //isi input id app.id = id //isi input nama depan app.first_name = first_name //isi input nama belakang app.last_name = last_name }, //metode untuk update data updateData: function(){ if(app.id == '' || app.first_name == '' || app.last_name == ''){ alert('isi semua data terlebih dahulu!'); }else{ axios .post("action.php", { action: "update", id: app.id, first_name: app.first_name, last_name: app.last_name }) .then(function (response){ //memperbarui data app.fetchAllData() //menutup modal $("#modaledit").modal("hide"); //mengosongkan isi form app.id = '' app.first_name = '' app.last_name = '' }); } },


4.
Buka file action.php lalu copy script di bawah ini dan paste di bawah if($received_data->action == 'update'){ … }.
    
    

if($received_data->action == 'update') {     $data = array(         ':first_name' => $received_data->first_name, ':last_name' => $received_data->last_name, ':id' => $received_data->id ); $query = "UPDATE tbl_sample SET first_name = :first_name, last_name = :last_name WHERE id = :id"; $statement = $connect->prepare($query); $statement->execute($data); }



5. Jalankan project dengan mengakses localhost/latihan-crud-vue-php. Jika berhasil maka tampilannya akan tampak seperti gambar di bawah ini.
CRUD Vue dan Php
Hasil Akhir


Bagi yang kesulitan mengikuti step di atas, berikuti ini adalah script lengkap dari file index.html dan action.php

Script lengkap index.html dan script tutorial sebelumnya.
    

<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8" /> <meta http-equiv="X-UA-Compatible" content="IE=edge" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <title>Document</title> <link href="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/css/bootstrap.min.css" rel="stylesheet" integrity="sha384-EVSTQN3/azprG1Anm3QDgpJLIm9Nao0Yz1ztcQTwFspd3yD65VohhpuuCOmLASjC" crossorigin="anonymous" /> </head> <body> <!-- semua komponen yang ada di dalam id="crudApp" adalah vue --> <div class="container mt-4" id="crudApp"> <h2 class="alert alert-success text-center"> Latihan CRUD dengan menggunakan Vue Js dan MySQL </h2> <div class="card"> <div class="card-header"> <!-- tombol ini jika diklik maka akan menampilkan modal tambah --> <button class="btn btn-sm btn-success" data-bs-toggle="modal" data-bs-target="#modaltambah">Tambah Data</button> </div> <div class="card-body"> <table class="table table-striped"> <thead> <tr class="bg-dark text-white"> <th>No</th> <th>Nama Depan</th> <th>Nama Belakang</th> <th>Edit</th> <th>Hapus</th> </tr> </thead> <tbody> <!-- v-for digunakan untuk melakukna looping, seperti foreach pada php --> <!-- allData adalah variabel yang berisi data dari database, bagaimana allData bisa menampung data bisa kalian lihat pada script fetchAllData di bagian bawah --> <tr v-for="(item, index) in allData" :key="index"> <td>{{ index+1 }}</td> <td>{{ item.first_name }}</td> <td>{{ item.last_name }}</td> <td> <button class="btn btn-sm btn-success" data-bs-toggle="modal" data-bs-target="#modaledit" @click="editData(item.id, item.first_name, item.last_name)">Edit</button> </td> <td> <button class="btn btn-sm btn-danger">Hapus</button> </td> </tr> </tbody> </table> </div> </div> <!-- di bawah ini adalah modal tambah --> <div class="modal fade" id="modaltambah" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="exampleModalLabel">Form Tambah</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> <div class="form-group mb-2"> <label for="">Nama Depan</label> <input type="text" class="form-control" v-model="first_name"> </div> <div class="form-group"> <label for="">Nama Belakang</label> <input type="text" class="form-control" v-model="last_name"> </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> <button class="btn btn-primary" @click="simpanData">Kirim</button> </div> </div> </div> </div> <!-- di bawah ini adalah modal edit --> <div class="modal fade" id="modaledit" tabindex="-1" aria-labelledby="exampleModalLabel" aria-hidden="true"> <div class="modal-dialog"> <div class="modal-content"> <div class="modal-header"> <h5 class="modal-title" id="exampleModalLabel">Form Tambah</h5> <button type="button" class="btn-close" data-bs-dismiss="modal" aria-label="Close"></button> </div> <div class="modal-body"> <input type="hidden" id="id" v-model="id"> <div class="form-group mb-2"> <label for="">Nama Depan</label> <input type="text" class="form-control" v-model="first_name"> </div> <div class="form-group"> <label for="">Nama Belakang</label> <input type="text" class="form-control" v-model="last_name"> </div> </div> <div class="modal-footer"> <button type="button" class="btn btn-secondary" data-bs-dismiss="modal">Close</button> <button class="btn btn-primary" @click="updateData">Kirim</button> </div> </div> </div> </div> </div> <script src="https://cdn.jsdelivr.net/npm/bootstrap@5.0.2/dist/js/bootstrap.bundle.min.js" integrity="sha384-MrcW6ZMFYlzcLA8Nl+NtUVF0sA7MsXsP1UyJoMp4YLEuNSfAP+JcXn/tWtIaxVXM" crossorigin="anonymous"></script> <script src="https://code.jquery.com/jquery-3.5.1.js"></script> <script src="https://cdn.jsdelivr.net/npm/vue/dist/vue.js"></script> <script src="https://unpkg.com/axios/dist/axios.min.js"></script> <script> // inisialisasi vue var app = new Vue({ el: "#crudApp", data: { allData: "", first_name: "", last_name: "", id: "", }, methods: { //metode untuk menampilkan data fetchAllData: function () { axios .post("action.php", { action: "fetchall", }) .then(function (response) { // respon adalah data yang berhasil diambil dari database // respon.data adalah data yang dimasukan ke dalam variabel allData // allData akan dilooping di tabel nantinya app.allData = response.data; }); }, //metode untuk insert data simpanData: function(){ if(app.first_name == '' || app.last_name == ''){ alert('isi semua data terlebih dahulu!'); }else{ axios .post("action.php", { action: "insert", first_name: app.first_name, last_name: app.last_name }) .then(function (response){ //memperbarui data app.fetchAllData() //menutup modal $("#modaltambah").modal("hide"); //mengosongkan isi form app.first_name = '' app.last_name = '' }); } }, //isi form saat modal edit tampil editData: function(id, first_name, last_name){ //isi input id app.id = id //isi input nama depan app.first_name = first_name //isi input nama belakang app.last_name = last_name }, //metode untuk update data updateData: function(){ if(app.id == '' || app.first_name == '' || app.last_name == ''){ alert('isi semua data terlebih dahulu!'); }else{ axios .post("action.php", { action: "update", id: app.id, first_name: app.first_name, last_name: app.last_name }) .then(function (response){ //memperbarui data app.fetchAllData() //menutup modal $("#modaledit").modal("hide"); //mengosongkan isi form app.id = '' app.first_name = '' app.last_name = '' }); } }, }, // semua yang ada di dalam creadted akan dijalankan saat pertama kali document dimuat created: function(){ this.fetchAllData() } }); </script> </body> </html>

Script lengkap action.php dan script tutorial sebelumnya.
    

<?php //koneksi ke database dnegan PDO $connect = new PDO("mysql:host=localhost;dbname=latihan", "root", ""); $received_data = json_decode(file_get_contents("php://input")); //script untuk menampilkan semua data if($received_data->action == 'fetchall') { //membuat variabel data //variabel ini akan digunakan untuk menampung data dari database nantinya $data = array(); //perintah untuk mengambil data dari database $query = "SELECT * FROM tbl_sample ORDER BY id DESC"; $statement = $connect->prepare($query); $statement->execute(); //melakukan perulangan dan memasukan tiap data ke dalam variabel data while($row = $statement->fetch(PDO::FETCH_ASSOC)){ $data[] = $row; } //menampilkan data dalam bentuk json echo json_encode($data); } if($received_data->action == 'insert') { $data = array( ':first_name' => $received_data->first_name, ':last_name' => $received_data->last_name ); $query = "INSERT INTO tbl_sample (first_name, last_name) VALUES (:first_name, :last_name)"; $statement = $connect->prepare($query); $statement->execute($data); } if($received_data->action == 'update') { $data = array( ':first_name' => $received_data->first_name, ':last_name' => $received_data->last_name, ':id' => $received_data->id ); $query = "UPDATE tbl_sample SET first_name = :first_name, last_name = :last_name WHERE id = :id"; $statement = $connect->prepare($query); $statement->execute($data); } ?>

Ok sekian tutorial kita kali ini CRUD Vue dan PHP Part 3: Update Data ke MySQL. Semoga bermanfaat, Jika ada yang ingin ditanyakan silahkan tanya langsung di kolom komentar di bawah ini atau tanya langsung di fanspage sahretech. Sekian dan sampai jumpa.

2 comments:

Jangan lupa kasih komentar ya!. Karena komentar kalian membantu kami menyediakan informasi yang lebih baik

Tidak boleh menyertakan link atau promosi produk saat berkomentar. Komentar tidak akan ditampilkan. Hubungi 081271449921(WA) untuk dapat menyertakan link dan promosi