动态获取填充表格数据时的特定值的赋值

1、如图:将动态获取的值columnKey转换为"Y"或“”N“”
在这里插入图片描述

<el-table
          v-loading="loading"
          :data="columnList"
          border
          tooltip-effect="dark"
          :size="tableSize"
          :height="tableHeight"
          style="width: 100%; margin: 15px 0"
        >
          <el-table-column type="selection" width="55" align="center" />
          <el-table-column label="序号" width="55" align="center">
            <template slot-scope="scope">
              <span>{{ scope.$index + 1 }}</span>
            </template>
          </el-table-column>
          <template v-for="(item, index) in tableColumns">
            <el-table-column
              v-if="item.show"
              :key="index"
              :prop="item.prop"
              :label="item.label"
              :formatter="item.formatter"
              align="center"
              show-overflow-tooltip
            />
          </template>
          <el-table-column
            label="操作"
            align="center"
            class-name="small-padding fixed-width"
          >
            <template slot-scope="scope">
              <el-popover placement="left" trigger="click">
                <el-button
                  v-hasPerm="['metadata:datacolumn:detail']"
                  size="mini"
                  type="text"
                  icon="el-icon-view"
                  @click="handleDetail(scope.row)"
                  >详情</el-button
                >
                <el-button slot="reference">操作</el-button>
              </el-popover>
            </template>
          </el-table-column>
        </el-table>

2、注意 tableColumns里的 formatter: this.keyFormatter

data() {
    return {
      activeName: 'first',
      tableHeight: document.body.offsetHeight - 310 + "px",
      // 展示切换
      showOptions: {
        data: {},
        showList: true,
        showDetail: false,
      },
      // 遮罩层
      loading: true,
      // 表格头
      tableColumns: [
        { prop: "columnName", label: "字段名称", show: true },
        { prop: "columnComment", label: "字段注释", show: true },
        {
          prop: "columnKey",
          label: "是否主键",
          show: true,
          formatter: this.keyFormatter,
        },
        {
          prop: "columnNullable",
          label: "是否允许为空",
          show: true,
          formatter: this.nullableFormatter,
        },
        { prop: "dataType", label: "数据类型", show: true },
        { prop: "dataLength", label: "数据长度", show: true },
        { prop: "dataPrecision", label: "数据精度", show: true },
        { prop: "dataScale", label: "数据小数位", show: true },
        { prop: "dataDefault", label: "数据默认值", show: true },
      ],
      // 默认选择中表格头
      checkedTableColumns: [],
      tableSize: "medium",
      // 表格数据
      columnList: [],
      // 总数据条数
      total: 0,
      // 左侧树
      treeOptions: [],
      defaultProps: {
        children: "children",
        label: "label",
      },
    };
  },

3、keyFormatter

keyFormatter(row, column, cellValue, index) {
      if (cellValue === "1") {
        return "Y";
      } else {
        return "N";
      }
    },
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
如果你想使用Java将Excel数据导入到嵌套对象中,可以使用Apache POI和Java反射。 以下是一个示例代码,演示了如何动态填充嵌套对象的属性: 假设我们有以下两个类: ```java public class Address { private String street; private String city; private String state; private String zipCode; // getters and setters } public class Person { private String name; private int age; private Address address; // getters and setters } ``` 假设我们已经将Excel表格中的数据读入到了一个List<List<String>>对象中,其中每个List<String>对象表示一行Excel数据。下面的代码展示了如何使用反射和Apache POI将数据填充到Person对象中: ```java import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import java.lang.reflect.Field; import java.util.List; public class ExcelReader { public static void main(String[] args) { // 假设我们已经将Excel表格中的数据读入到了一个List<List<String>>对象中 List<List<String>> excelData = getExcelData(); // 创建一个名为"Sheet1"的工作表 Sheet sheet = workbook.getSheet("Sheet1"); // 获取工作表中的数据行 for (int i = 1; i < sheet.getPhysicalNumberOfRows(); i++) { Row row = sheet.getRow(i); // 创建Person对象 Person person = new Person(); // 使用反射获取Person对象中的所有属性 Field[] fields = Person.class.getDeclaredFields(); // 遍历所有属性 for (int j = 0; j < fields.length; j++) { Field field = fields[j]; // 获取属性名 String fieldName = field.getName(); // 获取属性 Cell cell = row.getCell(j); Object cellValue = null; if (cell != null) { CellType cellType = cell.getCellType(); if (cellType == CellType.STRING) { cellValue = cell.getStringCellValue(); } else if (cellType == CellType.NUMERIC) { cellValue = cell.getNumericCellValue(); } } // 如果属性为null,则跳过 if (cellValue == null) { continue; } // 如果属性名为address,则填充Address对象的属性 if (fieldName.equals("address")) { // 创建Address对象 Address address = new Address(); // 获取Address对象中的所有属性 Field[] addressFields = Address.class.getDeclaredFields(); // 遍历所有属性 for (int k = 0; k < addressFields.length; k++) { Field addressField = addressFields[k]; // 获取属性名 String addressFieldName = addressField.getName(); // 获取属性 Cell addressCell = row.getCell(j + k + 1); Object addressCellValue = null; if (addressCell != null) { CellType addressCellType = addressCell.getCellType(); if (addressCellType == CellType.STRING) { addressCellValue = addressCell.getStringCellValue(); } else if (addressCellType == CellType.NUMERIC) { addressCellValue = addressCell.getNumericCellValue(); } } // 如果属性为null,则跳过 if (addressCellValue == null) { continue; } // 使用反射设置Address对象的属性 try { Field addressField = Address.class.getDeclaredField(addressFieldName); addressField.setAccessible(true); addressField.set(address, addressCellValue); } catch (NoSuchFieldException | IllegalAccessException e) { e.printStackTrace(); } } // 设置Person对象的address属性 person.setAddress(address); } else { // 使用反射设置Person对象的属性 try { field.setAccessible(true); field.set(person, cellValue); } catch (IllegalAccessException e) { e.printStackTrace(); } } } // 打印Person对象的属性 System.out.println(person); } } } ``` 这个示例代码中,我们首先使用反射获取了Person类中的所有属性,然后遍历了Excel表格中的数据行,并使用反射和Apache POI将数据填充到Person对象中。当属性名为address,我们创建了一个新

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值