我有一个订单列表,其中每个订单都可以点击以查看订单详细信息。
我已经使用了几个小时的调试来尝试理解为什么id属性在着陆页上为null,但是通过商店和api调用函数看起来很好。
描述这个的最好方法是通过代码,所以看看(请参阅ID仍然具有有效值的注释)。
- >工作路线
{ path: '/vieworder/:id', component: ViewOrder, props: true },
- > ROUTE PUSH TO DETAILS页面:
methods: {
...mapActions(['getOrders']),
init() {
this.getOrders()
},
viewOrder: function(order){
this.$router.push('/vieworder/' + order.id)
}
},
- > VIEWORDER.VUE(ID在模板中为空...)
import * as types from '../store/mutationtypes'
import { mapGetters, mapActions } from 'vuex'
export default {
name: 'ViewOrder',
props: {
id: {
type: String,
required: true
}
},
created() {
this.$store.dispatch('getOrderById', {
id: this.id
})
console.log('The id is now : ' + this.id)
},
computed: {
...mapGetters(["order"])
}
}
<template>
<div class="col-sm-10 col-sm-offset-1">
<h4>{{ order.id }}</h4>
</div>
</template>
- &GT;商店和GETORDERBYID(ID值在这里正确...)
export default new Vuex.Store({
state: {
orders: [],
order: null
},
getters: {
orders: state => state.orders,
order: state => state.order
},
actions: {
getOrders({ commit }) {
api.getOrders().then(orders => commit(types.UPDATE_ORDERS, orders))
},
getOrderById({ commit }, { id }){
console.log("In Store now - Do we have an id ? : " + id)
api.getOrderById(id).then(order => commit(types.UPDATE_ORDER, order))
},
etc.etc.etc...
- &GT; API CALL返还数据
getOrderById(orderId){
return axios.get('http://localhost:3000/Orders/' + orderId)
.then(response => response.data)
},
- &GT;从API CALL返回的示例数据
"Orders": [
{
"id": 123456,
"PaidDate": "2017-01-12",
"AppId": "KLM-UXI-NIX-FIX",
"TicketType": "Barn - Enkeltbillett",
"TicketCount": 1,
"OrderSum": "17",
"MediaChannel": "Android",
"StatusCode": "08-12-34-56-78",
"PaymentOption": "VISA"
},
答案 0 :(得分:1)
如果订单为空,您可以尝试在vuex中将getOrderById({ commit }, { id })
更改为getOrderById({ commit }, id)
,并在this.$store.dispatch('getOrderById', id)
挂钩中将其称为mounted()
。
此外,您可以检查订单是否存在,如同<div class="col-sm-10 col-sm-offset-1" v-if="order.id">
一样,以避免在获取数据之前出现错误。
答案 1 :(得分:1)
这不是对OP具体情况的答案,而是对问题标题的回答。我从vuejs收到了相同的控制台错误消息“无法读取null的属性ID”或“无法读取undefined的属性ID”。
我最终通过检查所有代码并确保每次使用“ x.id”都在“ if(x)”之类的代码块中来解决了该问题。例如,如果在vue组件的“ props”中设置了“ x”,则由于“无法读取未定义的属性ID”,以下内容可能会失败:
<div v-for="y in x" :key="y.id">
{{ y.name }}
</div>
解决方案是将其包装在v-if
块中,如下所示:
<div v-if="x">
<div v-for="y in x" :key="y.id">
{{ y.name }}
</div>
</div>
类似地,在计算属性中,以下内容可能会失败:
computed: {
sumids: function () {
var finalsum = 0
for (var y of this.x) {
finalsum += y.id
}
return finalsum
}
},
解决方案是将其包装在if
块中,如下所示:
computed: {
sumids: function () {
var finalsum = 0
if (this.x) {
for (var y of this.x) {
finalsum += y.id
}
}
return finalsum
}
},