el-table 纵向垂直表头

html 复制代码
<template>
  <div class="element-main">
    <div> Element-ui 官方提供 table Demo</div>
    <el-table
      border
      style="width: 100%"
      :data="tableData">
      <el-table-column prop="courseName" label="课程信息" width="180"></el-table-column>
      <el-table-column prop="courseBook" label="教材信息" width="180"></el-table-column>
      <el-table-column prop="price" label="单价"></el-table-column>
    </el-table>
    <div>===================================== 分割线 =====================================</div>
    <div>行列转换后的 Demo</div>
    <el-table
      border
      style="width: 100%"
      :data="getValues"
      :show-header="false">
      <el-table-column
        v-for="(item, index) in getHeaders"
        :key="index"
        :prop="item">
      </el-table-column>
    </el-table>
  </div>
</template>

<script>
export default {
  data() {
    return {
      headers: [
        {prop: 'courseName',label: '课程信息'},
        {prop: 'courseBook', label: '教材信息'},
        {prop: 'price',label: '单价'},
      ],
      tableData:[
        {"courseId": 1,"courseName": "英语写作", "courseBook": "英语写作基础教程","price": 3500},
        {"courseId": 2,"courseName": "综合英语(三)",": "新编英语教程2","price": 3350}, 
        {"courseId": 3,"courseName": "英语国家社会与文化","courseBook": "致用英语 英语国家概况 (第二版)","price": 2900 },
        {"courseId": 3,"courseName": "英语国家社会与文化","courseBook": "致用英语 英语国家概况 (第二版)","price": 2900,}
     ],
    }
  },
  computed: {
    getHeaders() {
      return this.tableData.reduce((pre, cur, index) => pre.concat(`value${index}`), ['title'])
    },
    getValues() {
      return this.headers.map(item => {
        return this.tableData.reduce((pre, cur, index) => Object.assign(pre, {['value' + index]: cur[item.prop]}), {'title': item.label,});
      });
    }
  },
};
</script>

参考链接:https://www.jianshu.com/p/1f38eaffd070

相关推荐
暴富的Tdy12 小时前
【使用 Vue2 脚手架创建项目并实现主题切换功能涵盖Ant-Design-Vue2/Element-UI】
vue.js·elementui·anti-design-vue·vue切换主题
小魏的马仔13 小时前
【elementui】el-date-picker日期选择框,获取焦点后宽度增加问题调整
前端·vue.js·elementui
道之极万物灭1 天前
NiceGUI之Button操作(ElementPlus组件库)
python·elementui·web组件·nicegui
芳草萋萋鹦鹉洲哦2 天前
【elementUI】form表单rules没生效
前端·javascript·elementui
一只小阿乐2 天前
前端vue3 web端中实现拖拽功能实现列表排序
前端·vue.js·elementui·vue3·前端拖拽
方安乐3 天前
vue3 el-select懒加载以及自定义指令
javascript·vue.js·elementui
哆啦A梦15883 天前
商城后台管理系统 02 添加规格参数-动态表单
javascript·vue.js·elementui
哆啦A梦15883 天前
商城后台管理系统 03 规格参数配置
javascript·vue.js·elementui
一路向前的月光4 天前
Eltable二次封装
javascript·vue.js·elementui
哆啦A梦15884 天前
商城后台管理系统 04 登录-功能实现-数据持久化-vuex
javascript·vue.js·elementui