gpt4 book ai didi

javascript - 在 vueJs 上更新 firebase 绑定(bind)数组上的元素

转载 作者:搜寻专家 更新时间:2023-10-30 22:48:33 24 4
gpt4 key购买 nike

我有这个 Orders 数组,在内部 div 订单上,我检查它的状态。

<div class="list-group" v-for="(order, key) in orders">
<div class="order" v-if="checkOrderStatus(order.status)">
<div class="dishes">
<ul id="dishes" v-for="dish in order.dishes" >
<li v-if="checkDishOnOrder(dish)">{{checkDishOnOrder(dish).quantity}} x {{checkDishOnOrder(dish).dishName}}</li>
</ul>
</div>
<div class="notInclude">
<ul id="notInclude" v-for="dish in order.dishes" >
<li v-if="checkForNotInclude(dish)">{{checkForNotInclude(dish)}}</li>
</ul>
</div>
<div class="table">
<center><span id="table">{{order.tableID}}</span></center>
</div>
<div class="hour">
<center><span id="hour">{{order.hour}}</span></center>
</div>
<div class="status">
<center><button type="button" id="status" :class="{'doingOrder' : order.status == 'Pedido pronto', 'orderDone' : order.status == 'Pronto para entrega'}" @click="changeStatus(order)">{{order.status}}</button></center>
</div>

</div>
</div>

beforeCreate: 上,我用 firebase ref 绑定(bind)了这个数组:

this.$bindAsArray('orders', database.ref('orders/' + user.uid).orderByChild('hourOrder'))

问题是,每次我更改订单状态时,数组的最后一个元素都会一起更改,这是不应该发生的。

这是我的 checkOrderStatus: 函数:

checkOrderStatus: function(orderStatus) {
if(this.orderType == 'Em andamento') {
if(orderStatus != "Pronto para entrega") {
return true
}
} else if (this.orderType == 'Pedidos feitos') {
if(orderStatus == "Pronto para entrega") {
return true
}
}

},

这是 changeStatus: 函数:

changeStatus: function(order) {
var that = this;
var database = Firebase.database();
var loggedUser = Firebase.auth().currentUser;

if (order.status == 'Em andamento') {
order.status = 'Pedido pronto';

var orderKey = order['.key'];
delete order['.key'];

var updates = {};
updates['orders/' + loggedUser.uid + '/'+ orderKey] = order;

database.ref().update(updates).then(function() {
console.log('order Updated');

})
}
else if(order.status == 'Pedido pronto') {
order.status = 'Pronto para entrega';

var orderKey = order['.key'];
delete order['.key'];

var updates = {};
updates['orders/' + loggedUser.uid + '/'+ orderKey] = order;

database.ref().update(updates).then(function() {
console.log('order Updated');

})
}

},

最佳答案

我找到了一种使用计算属性来避免这种行为的方法:

computed: {
fixedOrders() {
var database = Firebase.database();
this.$bindAsArray('orders', database.ref('orders/' + this.userID).orderByChild('hourOrder'))
return this.orders
},
}

我已将数组再次绑定(bind)到一个计算属性上,因此它始终具有正确的订单值。

我只是担心性能损失,因为每次更改时我都会再次对订单数组出价。

关于javascript - 在 vueJs 上更新 firebase 绑定(bind)数组上的元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/44138649/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com