Vue如何动态修改el-table的某列数据

作者:guohongyanghy

这篇文章主要介绍了Vue如何动态修改el-table的某列数据,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教

动态修改el-table的某列数据

1.对话框打开时调用函数open@opened="checked"

2.可编辑

<el-table-column
    --------
visEdit="true"

3.同步选中的数据List:multipleSelection ,函数  checked: function () 

设置el-table某一列点击出现输入框可以编辑

设置el-table 某一列点击出现输入框可以编辑,鼠标失去输入框焦点时输入框消失,显示对应的值。

如下图所示:

具体实现:

<el-table :data="tableData" v-loading="loading" :row-class-name="tableRowClassName" border max-height="780" style="width: 100%" size="mini" @cell-click="tabClick">      
        <el-table-column label="顺序" prop="adSort">
          <template slot-scope="scope">
            <span v-if="scope.row.index === tabClickIndex && tabClickLabel === '顺序'">
              <el-input v-model="scope.row.adSort" type="number" maxlength="20" placeholder="请输入顺序" size="mini" @blur="inputBlur(scope.row)" />
            </span>
            <span v-else>{{ scope.row.adSort }}</span>
          </template>
        </el-table-column>
</el-table>

通过 tableRowClassName 设置每一行的index:

tableRowClassName ({ row, rowIndex }) {
      // 把每一行的索引放进row
      row.index = rowIndex

行点击事件,当某一行被点击时,该行的某列设置 tabClickIndex:

v-if="scope.row.index === tabClickIndex && tabClickLabel === '顺序'" 

所以当前点击行的某列会出现输入框:

// tabClick row 当前行 column 当前列
tabClick (row, column, cell, event) {
      switch (column.label) {
        case '顺序':
          this.tabClickIndex = row.index
          this.tabClickLabel = column.label
          break
        default: return
      console.log('tabClick', this.tabClickIndex, row.adName, row.adSort)

鼠标失焦事件:

// 失去焦点初始化
inputBlur (row) {
      // console.log('row', row)
      this.tabClickIndex = null
      this.tabClickLabel = ''     

以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

您可能感兴趣的文章:
  • vant/vue跨域请求解决方案
    vant/vue跨域请求解决方案
    2022-12-12
  • 一次用vue3简单封装table组件的实战过程
    一次用vue3简单封装table组件的实战过程
    2022-12-12
  • Vue2中如何使用全局事件总线实现任意组件间通信
    Vue2中如何使用全局事件总线实现任意组件间通信
    2022-12-12
  • element如何初始化组件功能详解
    element如何初始化组件功能详解
    2022-12-12
  • Vue中watch清除过期副作用的案例详解
    Vue中watch清除过期副作用的案例详解
    2022-12-12
  • Vue中iframe 结合 window.postMessage 实现跨域通信
    Vue中iframe 结合 window.postMessage 实现
    2022-12-12
  • Vue 使用postMessage 实现父子跨域通信
    Vue 使用postMessage 实现父子跨域通信
    2022-12-12
  • Vue中addEventListener() 监听事件案例讲解
    Vue中addEventListener() 监听事件案例讲解
    2022-12-12
  • 美国设下计谋,用娘炮文化重塑日本,已影响至中国
    美国设下计谋,用娘炮文化重塑日本,已影响至中国
    2021-11-19
  • 时空伴随者是什么意思?时空伴随者介绍
    时空伴随者是什么意思?时空伴随者介绍
    2021-11-09
  • 工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    工信部称网盘企业免费用户最低速率应满足基本下载需求,天翼云盘回应:坚决支持,始终
    2021-11-05
  • 2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2022年放假安排出炉:五一连休5天 2022年所有节日一览表
    2021-10-26
  • 电脑版 - 返回首页

    2006-2024 脚本之家 JB51.Net , All Rights Reserved.
    苏ICP备14036222号