ElementPlus Table 表格实现可编辑单元格

通过基础的Table表格来实现单元格内容的可编辑

 

 1.首先定位到需要编辑的列,替换el-table-column

           <el-table-column label="Editable Column" width="300">
              <template #default="{ row, column, $index }">
                <el-input
                  size="small"
                  v-if="
                   tableRowEditId === row.id &&
                   tableColumnEditIndex === column.id
                  "
                  v-model="row.taskId"
                  @blur="blurUnitInput(row, column)"
                  @keyup.enter="blurUnitInput(row, column)"
                />
                <span v-else class="hover-border">{{ row.taskId }}</span>
              </template>
            </el-table-column>

2.el-table 标签下面增加 cell-click 事件,当某个单元格被点击时会触发该事件

  <el-table :data="tableData" border style="width: 100%" @cell-click="showUnitInput">
    <el-table-column prop="date" label="Date" width="180" />
    <el-table-column prop="name" label="Name" width="180" />
     <el-table-column label="Editable Column" width="300">
              <template #default="{ row, column, $index }">
                <el-input
                  size="small"
                  v-if="
                   tableRowEditId === row.id &&
                   tableColumnEditIndex === column.id
                  "
                  v-model="row.taskId"
                  @blur="blurUnitInput(row, column)"
                  @keyup.enter="blurUnitInput(row, column)"
                />
                <span v-else class="hover-border">{{ row.taskId }}</span>
              </template>
            </el-table-column>
  </el-table>

3. 增加标识变量、事件方法,可以在 blurUnitInput 方法里面实现修改的接口

const tableRowEditId = ref()
const tableColumnEditIndex = ref()
const showUnitInput = (row: any, column: any) => {
  // console.log('row', row)
  // console.log('column', column)
  //赋值给定义的变量
  tableRowEditId.value = row.id //确定点击的单元格在哪行 如果数据中有ID可以用ID判断,没有可以使用其他值判断,只要能确定是哪一行即可
  tableColumnEditIndex.value = column.id //确定点击的单元格在哪列
}
const blurUnitInput = (row: { [x: string]: boolean }, column: any) => {
  tableRowEditId.value = null
  tableColumnEditIndex.value = null
  //在此处调接口传数据
  console.log(row)
  console.log(column)
}

4.增加一个样式,使可编辑的单元格鼠标悬停时显示虚线边框

.hover-border {
  border: none; /* 默认无边框 */

}

.hover-border:hover {
  border: 1px dotted #165DFF; /* 鼠标悬停时显示虚线边框 */
  padding: 2px;
}
Element Plus 提供了一种方便的方法来实现表格可编辑功能。通过使用双击事件、输入框和数据绑定,可以实现表格中编辑单元格的功能。首先,在双击单元格时显示输入框,通过绑定输入框的值与选中的单元格数据建立关联。当输入框失焦或按下 Enter 键后,将输入框的值赋给选中的单元格数据,从而实现编辑功能。此外,还可以通过右击单元格或表头打开菜单来进行其他操作。 示例代码基于Vue 3和Element Plus版本1.1.0-beta.12,需要注意的是,高版本的Element Plus中图标引入方式可能有所不同。 具体实现步骤如下: 1. 使用双击事件来触发编辑功能,例如使用 `@dblclick` 绑定到单元格上。 2. 在双击事件处理函数中,显示输入框,并将输入框的值与选中的单元格数据进行绑定。 3. 当输入框失焦或按下 Enter 键时,将输入框的值赋给选中的单元格数据,从而实现编辑功能。 4. 如果需要,在单元格或表头上绑定右击事件,例如使用 `@contextmenu` 绑定到单元格或表头上,在右击事件处理函数中可以打开菜单。 请参考如下代码示例: ```html <template> <el-table :data="tableData" @contextmenu="rightClick"> <el-table-column prop="name" label="姓名" v-for="column in columns"> <template #default="{ row }"> <span v-if="editRowIndex === row.index && editColumnIndex === column.index"> <input type="text" v-model="row[column.prop]" @blur="endEditing" @keyup.enter="endEditing" /> </span> <span v-else @dblclick="startEditing(row.index, column.index)">{{ row[column.prop }}</span> </template> </el-table-column> </el-table> </template> <script> export default { data() { return { columns: [ { prop: 'name', label: '姓名' }, // 其他列配置 ], tableData: [ { name: '张三' }, // 其他数据 ], editRowIndex: -1, editColumnIndex: -1, }; }, methods: { startEditing(rowIndex, columnIndex) { this.editRowIndex = rowIndex; this.editColumnIndex = columnIndex; }, endEditing() { this.editRowIndex = -1; this.editColumnIndex = -1; }, rightClick(event) { // 处理右击事件,打开菜单 }, }, }; </script> ``` 在上述代码中,使用了 `el-table` 和 `el-table-column` 组件来实现表格和列的渲染。通过在 `el-table-column` 的 `template` 中自定义单元格的显示方式,实现了根据编辑状态显示不同的内容。 在 `startEditing` 方法中,记录当前正在编辑的行索引和列索引,通过 `v-else` 条件来判断是否显示输入框或文本。 在 `endEditing` 方法中,结束编辑状态,将编辑后的值赋给选中的单元格数据。 需要注意的是,在实际使用时,可能还需要进行一些额外的处理,例如验证输入的内容是否有效、保存编辑后的数据等。 希望这个回答对您有帮助!<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [优雅的elementUI table单元格可编辑实现方法详解](https://download.csdn.net/download/weixin_38691669/12948236)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* *3* [vue3 + Element Plus动态生成表格,并实现内容可编辑](https://blog.csdn.net/ymzhaobth/article/details/104716431)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

今晚哒老虎

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值