Я пытаюсь создать страницу панели надстроек для отслеживания состояния моего приложения Python, запущенного на сервере.
На стороне сервера приложение python обновляет файл data.json при достижении определенного состояния.
На стороне клиента vue.js обрабатывает создание контента.
У меня проблема при попытке обновить индикатор выполнения, потому что мне нужно обновить страницу, чтобы отображался прогресс.
Есть ли у вас какие-либо предложения, как сделать индикатор прогресса в моем представлении без обновления?
index.html
<div class="item" v-for="item in order">>
<div class="progress">
<div class="progress-bar bg-warning" role="progressbar" aria-valuenow="50" aria-valuemin="0" aria-valuemax="100" :style="{ width: item.completion + '%' }">
</div>
</div>
</div>
app.js
window.addEventListener('load', () => {
window.vue = new Vue({
el: '#app',
name: 'Order',
data: {
isLoading: true,
order: [],
},
created() {
fetch('./data.json')
.then((res) => { return res.json() })
.then((res) => {
this.isLoading = false;
this.order = res.order;
})
}
})
});
data.json
{
"order": [
{
"customer": "Mr. Smith",
"price": "60",
"status": "Pending",
"orders": "Something",
"completion": 40,
"isAvailable": true,
"isEligible": true
}
]
}
edit: я решил проблему с добавлением watcher в app.js
watch: {
order() {
this.updateorder();
}
},
methods: {
updateorder() {
fetch('./data.json?_timestamp=' + Date.now())
.then((res) => { return res.json() })
.then((res) => {
this.order = res.order;
})