Element-plus虚拟化表格(JS版)-带单选框

大佬可以跳过~~~

DOM:(这个不用多说,官网有~)

<el-table-v2 :columns="columns" :data="list" :width="1150" :height="550" fixed />

JS:

const columns = [
  {
    width: 60,
    cellRenderer: ({ rowData }) => // 注意!这儿没有大括号!
      h(ElRadio, { // 需要引入element-plus的单选框
        label: rowData.name, // 为了使选中状态回显
        modelValue: state.templateRadio, // state.templateRadio为选中的值
        'onUpdate:modelValue': () => (state.templateRadio = rowData.name),
        onChange: (val) => {
          state.templateRadio = val
          // 选中单选框要处理的逻辑写在这儿
        }
      })
  },
  { title: '序号', key: 'index', cellRenderer: ({ rowIndex }) => `${rowIndex + 1}`, width: 80 },
  { title: '名称', key: 'name', dataKey: 'name', width: 400 },
  { title: '描述', key: 'desc', dataKey: 'desc', width: 400 }
]

开始遇到的问题是可以点击能拿到值但是不能回显,所以加上了label。
又学到了。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
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
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值