Моя проблема в том, что компонент Crud-Table не обновляется при изменении currentTable
. Когда я назначаю currentTable = 'doctor'
на created ()
или что-то еще. Это работает, но это не здесь. Почему?
<template>
<div id="adminpanel">
<div id="tabs">
<button
v-for="tableName in tables"
:key="tableName"
@click="switchTo(tableName)"
>{{ tableName }}
</button>
<crud-table :tableName="currentTable"/>
</div>
</div>
</template>
<script>
import CrudTable from './CrudTable.vue'
export default {
name: 'AdminPanel',
data () {
return {
tables: ['user', 'doctor'],
currentTable: 'user'
}
},
methods: {
switchTo: function (tableName) {
this.currentTable = tableName
}
},
components: {
CrudTable
}
}
</script>
Edit:
Это не дубликат, потому что я никоим образом не ошибся в названии реквизита. И это работает, когда я устанавливаю другое начальное значение.
Это мой компонент CrudTable:
<template>
<table id="crudtable">
<tr>
<th>Akcje</th>
<th v-for="h in header" :key="h">
{{ h }}
</th>
</tr>
<tr v-for="row in rows" :key="row.id">
<td>
<span class="action edit">E</span>
<span @click="save(visible(row))" class="action save">S</span>
<span class="action delete">D</span>
</td>
<td v-for="cell in ordered(visible(row))" :key="cell.name">
<input v-model="cell.value" type="text"/>
</td>
</tr>
</table>
</template>
<script>
import {HTTP} from '../http-common'
import {popUp} from '../utils'
export default {
name: 'CrudTable',
props: ['tableName'],
data () {
return {
rows: [],
header: [],
chunkSize: 10
}
},
computed: {
endpoint: function () {
return `/api/${this.tableName}`
}
},
methods: {
visible: function (row) {
let ret = {}
for (let prop in row) {
if (!prop.startsWith('_')) {
ret[prop] = row[prop]
}
}
return ret
},
ordered: function (row) {
let ret = []
for (let col of this.header) {
ret.push({name: col, value: row[col]})
}
return ret
},
fillTable: function () {
let self = this
let link = `${this.endpoint}/?page=0&size=100`
HTTP.get(link)
.then(function (response) {
self.rows = response.data
})
.catch(function (err) {
console.log(err.response)
})
},
fillHeader: function () {
let self = this
HTTP.get(self.endpoint)
.then(function (response) {
self.header = Object.keys(response.data)
})
.catch(function (err) {
console.log(err.response)
})
},
save: function (row) {
HTTP.patch(this.endpoint, row)
.then(function (response) {
popUp('ok', `Zapisano obiekt o id ${row.id}`)
})
.catch(function (err) {
console.log(err.response)
})
}
},
beforeMount () {
this.fillTable()
this.fillHeader()
}
}
</script>