0๐
โ
You should do it using the vue ecosystem without vanilla like this:
new Vue({
el: '#app',
data: {
items: [
{
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0
},
{
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0
}
],
newItem: {
product_no: '',
product_name: '',
product_price: '',
product_qty: '',
line_total: null
}
},
methods: {
addRow () {
this.items.push(this.newItem)
this.cleanForm()
},
cleanForm () {
this.newItem = {
product_no: '',
product_name: '',
product_price: '',
product_qty: '',
line_total: null
}
}
}
})
<!-- Load required Bootstrap and BootstrapVue CSS -->
<link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap/dist/css/bootstrap.min.css" />
<link type="text/css" rel="stylesheet" href="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.min.css" />
<!-- Load Vue followed by BootstrapVue -->
<script src="//unpkg.com/vue@latest/dist/vue.min.js"></script>
<script src="//unpkg.com/bootstrap-vue@latest/dist/bootstrap-vue.min.js"></script>
<div id="app">
<b-table striped hover :items="items">
</b-table>
No Produk : <input type="text" v-model="newItem.product_no" /><br>
Nama Produk : <input type="text" v-model="newItem.product_name" /><br>
Harga Produk : <input type="text"v-model="newItem.product_price" /><br>
Quantity Produk : <input type="text" v-model="newItem.product_qty" /><br>
Line Total : <input type="number" v-model="newItem.line_total" /><br>
<br><br>
<b-button @click="addRow">
<i class=""></i>Add Row
</b-button>
</div>
0๐
This might be helpful.
new Vue({
el: '#app',
data: {
items: [{
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0,
}, {
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0,
}],
counter: 3
},
methods:{
addTableRow: function () {
var obj = {
product_no: this.counter,
product_name: this.counter,
product_price: this.counter,
product_qty: this.counter,
line_total: this.counter
};
this.items.push(obj);
this.counter++;
}
}
});
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.5.17/vue.js"></script>
<div id="app">
<table>
<tr><th>Table</th></tr>
<tr v-for="item in items">
<td>{{ item.product_no }}</td>
<td>{{ item.product_name }}</td>
<td>{{ item.product_price }}</td>
<td>{{ item.product_qty }}</td>
<td>{{ item.line_total }}</td>
</tr>
</table>
<button @click='addTableRow()'>Add New Row</button>
</div>
0๐
Add temp data
Every addRow You take the data to items array and set the temp data
<template>
<div>
<b-table striped hover :items="items" id="table">
</b-table>
No Produk : <input type="text" id="no_product" v-model="temp.product_no" /><br>
Nama Produk : <input type="text" id="nama_product" v-model="temp.product_name" /><br>
Harga Produk : <input type="text" id="harga_product" v-model="temp.product_price" /><br>
Quantity Produk : <input type="text" id="qtt_product" v-model="temp.product_qty" /><br>
Line Total : <input type="text" id="line_totall" v-model="temp.line_total" /><br>
<br><br>
<b-button @click="addRow">
<i class=""></i>Add Row
</b-button>
</div>
</template>
and here is the script
<script>
export default {
data(){
return {
temp: {
product_no: '',
product_name: '',
product_price: '',
product_qty: '',
line_total: 0,
}
items: [{
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0,
}, {
product_no: '1',
product_name: 'kotak',
product_price: '10000',
product_qty: '5',
line_total: 0,
}]
}
},
methods: {
addRow() {
var table = document.getElementsByTagName('b-table')[0];
var newRow = table.insertRow(table.rows.length);
var cel1 = newRow.insertCell(0);
var cel2 = newRow.insertCell(1);
var cel3 = newRow.insertCell(2);
var cel4 = newRow.insertCell(3);
var cel5 = newRow.insertCell(4);
cel1.product_no = this.temp.product_no;
cel2.product_name = this.temp.product_name;
cel3.product_price = this.temp.product_price;
cel4.product_qty = this.temp.product_qty;
cel5.line_total = this.temp.line_total;
console.log(print);
this.temp = {
product_no: '',
product_name: '',
product_price: '',
product_qty: '',
line_total: this.items.length,
}
},
}
}
</script>
Source:stackexchange.com