写一个可编辑的表格

需求概述

表格的列来自于后台,要先把表格列循环出来,这里用本地data模拟一下;表格数据赋值的时候,要判断一下该属性是否是可编辑的,这里用到了插槽

完整代码

<template>
  <div>
    <el-row>
      <el-col :span="8">
        <el-table
          :data="tableData"
          style="width:100%"
          align="center"
          border>

          <!-- 表格列来自于tableHead这个数组,要把它循环出来 -->
          <template v-for="(item, index) in tableHead">
            <el-table-column
              :key="index"
              :prop="item.prop"
              :label="item.label"
              :min-width="item.width"
              show-overflow-tooltip
              resizable>
              
              <!-- 如果是sort或者 name列,就是可编辑的 -->
              <template slot-scope="scope">
                <el-input-number v-if="item.prop=='sort' ? true : false" size="small" :min="0" v-model="scope.row.sort"></el-input-number>
                <template v-else-if="numberEdit(item.prop)">
                  <el-input v-model="scope.row.name"></el-input>
                </template>

                <!-- 剩下的列用v-html静态显示就好 -->
                <template v-else>
                  <span v-html="scope.row[item.prop]"></span>
                </template>
              </template>
            </el-table-column>
          </template>
        </el-table>
      </el-col>
    </el-row>
  </div>
</template>

<script>
  export default {
    data() {
      return {
        tableHead:[], //存放表格列
        tableData:[] //存放表格数据
      };
    },
    created(){
      this.init();
    },
    methods: {
      //初始化,获取表格列和表格数据,这里本地模拟一下
      init(){
        this.tableHead = [
          { label:"姓名", prop:"name", align:"center", width:100 },
          { label:"学号", prop:"number", align:"center", width:100 },
          { label:"排序", prop:"sort", align:"center", width:100 }
        ];

        this.tableData = [
          { name:'一', number:'1089', sort:'4' },
          { name:'二', number:'1080', sort:'2' },
          { name:'三', number:'1084', sort:'3' },

        ];
      },

      //判断是否是可编辑的属性
      numberEdit(p){
        if(p == 'name'){
          return true;
        }else{
          return false;
        }
      }
    }
  };
</script>

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。 经导师精心指导并认可、获 98 分的毕业设计项目!【项目资源】:微信小程序。【项目说明】:聚焦计算机相关专业毕设及实战操练,可作课程设计与期末大作业,含全部源码,能直用于毕设,经严格调试,运行有保障!【项目服务】:有任何使用上的问题,欢迎随时与博主沟通,博主会及时解答。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值