我正在尝试访问 vue 组件计算属性中的 Object 属性,但我收到一条错误消息,指出该属性未定义。我在这里设置了一个原型。当我尝试使用
playerEntry.stats.RecYards["#text"] > "0"
Vue 抱怨
[Vue 警告]:渲染错误:“TypeError:playerentry.stats.RecYards 未定义”
并查看 Computed 下的 vue.js devtools 我看到playerReceivingStats:"(error during evaluation)" 这是相关代码:
boxscore.js
const boxScoresStats = {
stats: Vue.component("box-scores", {
props: ["props_box_score", "props_gameID"],
data: function() {
return {
playerStats: this.props_box_score.data.gameboxscore.awayTeam.awayPlayers
.playerEntry
};
},
computed: {
playerPassingStats: function() {
return this.playerStats.filter(playerEntry => {
return playerEntry.player.Position === "QB";
});
},
playerReceivingStats: function() {
return this.playerStats.filter(playerEntry => {
console.log(playerEntry.stats.RecYards["#text"]);
return playerEntry.stats.RecYards["#text"] > "0";
});
}
},
模板
<div v-for="playerStats in playerReceivingStats">
<tr class="d-flex">
<td class="col-3 justify-content-center" scope="row">
{{playerStats.player.FirstName}} {{playerStats.player.LastName}} ({{playerStats.player.Position}})
</td>
<td class="col-2 justify-content-center" justify-content="center">
{{ playerStats.stats.Receptions['#text'] }} </td>
<td class="col-3 justify-content-center">{{playerStats.stats.RecYards['#text']}}</td>
<td class="col-2 justify-content-center">{{playerStats.stats.RecTD['#text']}}</td>
<td class="col-2 justify-content-center">{{playerStats.stats.Targets['#text']}}</td>
</tr>
</div>
我已经尝试了括号和点符号,但仍然没有好处。我看到 console.log 中的值打印正常。但是当我可以在 devtools 中看到对象属性时,我不知道为什么它说未定义。另请注意,如果我将计算中的 eval 缩短为playerEntry.stats.RecYards我没有收到错误?但是我得到了不正确的结果。非常感谢任何帮助。
更新:
这是有效的计算属性:
playerReceivingStats: function() {
return this.offensivePlayers.filter(playerEntry => {
if (typeof playerEntry.stats.RecYards != "undefined") {
return playerEntry.stats.RecYards["#text"] > "0";
}
});
}
}