开发者问题收集

根据循环内的条件渲染不同的组件

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