Tutorial CRUD Vue dan PHP Part 2: Menambah Data ke MySQL

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


Cara Menambah Data dengan Vue ke MySQL

1. Buka file index.html di dalam file latihan-crud-vue-php sebelumnya. Lalu copy script di bawah ini dan paste di bawah tulisan <-- 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" required> </div> <div class="form-group">     <label for="">Nama Belakang</label>     <input type="text" class="form-control" v-model="last_name" required> </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>


2.
 Lalu copy script di bawah ini dan paste di bawah fetchAllData: function() {…}
	

//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 = ''     });     } },


3.
Buka file action.php lalu copy script di bawah ini dan paste di bawah if($received_data->action == ‘fetchall’){ … }.
	

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); }


4.
Jalankan project dengan mengakses localhost/latihan-crud-vue-php. Jika berhasil maka tampilannya akan tampak seperti gambar di bawah ini.

Tutorial CRUD Vue dan PHP Part 2: Menambah Data ke MySQL
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 dengan 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">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" required> </div> <div class="form-group"> <label for="">Nama Belakang</label> <input type="text" class="form-control" v-model="last_name" required> </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> <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 = '' }); } }, }, // semua yang ada di dalam creadted akan dijalankan saat pertama kali document dimuat created: function(){ this.fetchAllData() } });         </script>     </body> </html>


Script lengkap action.php dengan 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); } ?>

Ok sekian tutorial kita kali ini CRUD Vue dan PHP Part 2: Menambah 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


Tutorial CRUD Vue dan PHP

1. CRUD Vue dan PHP part 1: Menampilkan Data dari MySQL
2. CRUD Vue dan PHP part 2: Menyimpan Data ke MySQL
3. CRUD Vue dan PHP part 3: Update Data ke MySQL
4. CRUD Vue dan PHP part 4: Hapus Data di MySQL

No 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