Vue element-ui <el-table-column>格式化器-如何显示html?

新手上路,请多包涵

如何返回html格式的单元格值?

我想使用 <el-table-column> formatter 获取自定义格式的值(使用 html 或其他组件)。

 <el-table :data="data">
  <el-table-column v-for="(column, index) in columns"
                   :key="index" :label="column.label"
                   :formatter="column.formatter">
  </el-table-column>
</el-table>

 data() {
  return {
    columns: [
      {
        label: 'Created at',
        formatter: (row, col, value, index) => {
          return `<span class="date">${value}</span>`
        }
      },
      // edit:
      {
        label: 'Address',
        formatter: (row, col, value, index) => {
          return `<mini-map :data="${row}"></mini-map>`
        }
      }
      // other dynamic columns...
    ]
  }
}

但是单元格内容显示为转义的 html 字符串。有没有可能强制html?

EPIC 编辑: 我添加了一个带有解决方案的答案。

原文由 Daniel 发布,翻译遵循 CC BY-SA 4.0 许可协议

阅读 4.2k
2 个回答

好的,经过几个小时的头脑风暴,我找到了非常好的解决方案。我把它放在这里是为了其他人 - 我希望这对某人有所帮助。

自定义列中显示的值可以是:

  • 简单字符串(prop)

  • 格式化字符串(安全,没有任何 html 或组件,通过原始格式化程序)

  • 自定义值(html,组件,也安全!)

为了实现这一点,我必须创建自定义格式化程序组件,我将其放在文件夹中,即 /TableFormatters/

为此,有一个简单的功能组件 DatetimeFormatter 可以用图标显示日期时间。

TableFormatters/DatetimeFormatter.vue

 <template functional>
  <span>
    <i class="icon-date"></i> {{ props.row[props.column] }}
  </span>
</template>

<script>
  export default {
    name: 'DatetimeFormatter',
  }
</script>

这是列配置:

 import DatetimeFormatter from './TableFormatters/DatetimeFormatter'
// ...
data() {
  return {
    data: [/*...*/],
    columns: [
      name: {
        label: 'Name',
      },
      state: {
        label: 'State',
        formatter: row => {
            return 'State: '+row.state__label
        }
      },
      created_at: {
        label: 'Created at',
        formatter: DatetimeFormatter
      }
    ]
  }
}

现在是定义 <el-table> 的时候了:

 <el-table :data="data">
  <el-table-column
    v-for="(column, index) in columns"
    :key="index"
    :label="columns[column] ? columns[column].label : column"
    :prop="column"
    :formatter="typeof columns[column].formatter === 'function' ? columns[column].formatter : null">
    <template #default="{row}" v-if="typeof columns[column].formatter !== 'function'">
      <div v-if="columns[column].formatter"
        :is="columns[column].formatter"
        :row="row"
        :column="column">
      </div>
      <template v-else>
        {{ row[column] }}
      </template>
    </template>
  </el-table-column>
</el-table>

这就像一个魅力。格式化程序在这里发生了什么?首先,我们检查格式化程序是否设置为 function 。如果是这样,本机 <el-table-column> 格式化程序将控制,因为 <template #default={row}> 将不会被创建。否则将创建格式化程序组件(通过 :is 属性)。但是,如果没有格式化程序,将显示一行的普通值。

原文由 Daniel 发布,翻译遵循 CC BY-SA 4.0 许可协议

如果要为 <el-table-column> 呈现自定义 HTML,则需要使用 自定义列模板 功能,而不是 :formatter 。它看起来像这样:

 <el-table :data="data">
  <el-table-column
    v-for="(column, index) in columns"
    :key="index"
    :label="column.label"
  >
    <template slot-scope="scope">
      <span class="date">{{ scope.row.value }}</span>
    </template>
  </el-table-column>
</el-table>

在一般情况下,如果需要呈现未转义的 HTML,可以使用 v-html 指令。这涉及到一些安全隐患,因此请确保在 v-html 之前了解这些内容。

从本质上讲,它归结为: 永远不要 使用 v-html 来呈现用户提供的内容。

原文由 Vince 发布,翻译遵循 CC BY-SA 4.0 许可协议

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题