根据循环内的条件渲染不同的组件
2019-06-01
287
我创建了一个简单的扫雷游戏,当决定渲染哪个单元格时,有三种可能性:
- 未显示的单元格
- 显示的地雷单元格
- 显示的中性单元格
我创建了一个行组件,用于渲染该行包含的所有单元格。
<template>
<div class="row">
<component
v-for="(cell, columnIndex) in row"
:key="columnIndex"
/>
</div>
</template>
我现在必须添加条件语句。从文档中有一个
is
标签,所以我尝试将我的代码扩展到
<component
v-for="(cell, columnIndex) in row"
:key="columnIndex"
:is="
if(cell.revealed){
if(cell.isMine) {
<RevealedMineCell/>
} else {
<RevealedNeutralCell
:mineNeighbours="cell.mineNeighbours"
/>
}
} else {
<UnrevealedCell
:unrevealedCell="cell"
:x="columnIndex"
:y="rowIndex"
@cellClicked="onCellClicked"
/>
}
"
/>
但我将 JavaScript 代码与 HTML 代码混合在一起,这是无效的。我想要做的就是类似这样的伪代码
<component
v-for="(cell, columnIndex) in row"
:key="columnIndex"
>
<v-if="cell.revealed && cell.isMine">
<RevealedMineCell/>
</v-if>
<v-else-if="cell.revealed && !cell.isMine">
<RevealedNeutralCell
:mineNeighbours="cell.mineNeighbours"
/>
</v-else-if>
<v-else>
<UnrevealedCell
:unrevealedCell="cell"
:x="columnIndex"
:y="rowIndex"
@cellClicked="onCellClicked"
/>
</v-else>
</component>
我该如何实现这一点?
1个回答
您可以在方法内部实现此目的。
<component
v-for="(cell, columnIndex) in row"
:key="columnIndex"
v-bind="getProps(cell)"
:is="getCellComponent(cell)"
/>
import RevealedMineCell from ...
import RevealedNeutralCell from ...
import UnrevealedMineCell from ...
...
methods: {
getProps (cell) {
if(cell.revealed){
if(cell.isMine) {
return {};
} else {
return {
mineNeighbours: cell.mineNeighbours
};
}
} else {
return {
unrevealedCell: cell,
...
...
cellClicked: this.onCellClicked
...
...
};
}
},
getCellComponent (cell) {
if(cell.revealed){
if(cell.isMine) {
return RevealedMineCell;
} else {
return RevealedNeutralCell;
}
} else {
return UnrevealedCell;
}
}
...
Mitro
2019-06-01