vue el-table字段点击出现el-input输入框,失焦保存方式

 更新时间:2024年02月28日 09:57:10   作者:Lemon今天学习了吗  
这篇文章主要介绍了vue el-table字段点击出现el-input输入框,失焦保存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教

一、效果展示

当没有数据初始化展示如下:

有数据展示数据,点击出现输入框, 失焦保存修改

二、代码实现

<!-- @cell-click="cellClick" 当前单击的单元格 -->
<el-table
    ref="table"
    size="mini"
    height="100%"
    row-key="id"
    :data="tableData"
    :row-class-name="getRowClass"
    @cell-click="cellClick"
 >
 <el-table-column width="100" label="排序" show-overflow-tooltip>
  <template slot-scope="scope">
    <span
      v-if="
        scope.row.index === dbClickIndex &&
        dbClickLabel === '排序'
      "
    >
      <el-input
        ref="sortNumRef"
        v-model="sortNum"
        placeholder="请输入"
        @blur="inputBlur(scope.row)"
        :pattern="numberPattern"
      />
    </span>
    <div v-else>
      <div class="flex_between cursor_pointer">
        <span
          :style="{ color: !scope.row.sortNum ? '#bbb' : '' }"
          >{{ scope.row.sortNum || '请输入' }}</span
        >
        <i class="el-icon-edit" style="color: #1989fe"></i>
      </div>
    </div> 
  </template>
 </el-table-column>
</el-table>
 data() {
    return {
      sortNum: null,
      dbClickIndex: null, // 点击的单元格
      dbClickLabel: '', // 当前点击的列名
      numberPattern: '[1-9]\\d*', // 正则表达式,限制只能输入正整数
    }
 }
 
methods:{
 // 把每一行的索引放进row
    getRowClass({ row, rowIndex }) {
      row.index = rowIndex
    },
  //  row 当前行 column 当前列
    cellClick(row, column, cell, event) {
      if (column.label === '排序') {
        this.dbClickIndex = row.index
        this.dbClickLabel = column.label
        this.sortNum = row.sortNum
        //聚焦input
        this.$nextTick(() => {
          this.$refs.sortNumRef.focus()
        })
      }
    },
    // 失去焦点初始化
    inputBlur(row, event, column) {
      this.editThemeIndex(row)
      this.dbClickIndex = null
      this.dbClickLabel = ''
      this.sortNum = null
    },
    // 编辑主题指标列表-排序字段
    editThemeIndex(row) {
      if (this.sortNum === '' || this.sortNum === row.sortNum) return
      const params = {
        sortNum: Number(this.sortNum) || '',
        id: row.id
      }
      //接口请求
      xxxApi(params).then((res) => {
        if (res.code === 200) {
          this.$message.success('修改成功')
          this.refreshClick()
        }
      })
    },
    // 刷新
    refreshClick(val) {
      this.pages.pageIndex = 1
      this.initTable()
    }
  }

总结

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

相关文章

  • vue切换菜单取消未完成接口请求的案例

    vue切换菜单取消未完成接口请求的案例

    这篇文章主要介绍了vue切换菜单取消未完成接口请求的案例,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧
    2020-11-11
  • vue.js实现双击放大预览功能

    vue.js实现双击放大预览功能

    这篇文章主要为大家详细介绍了vue.js实现双击放大预览功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-06-06
  • 一文详解如何创建Vue3项目及组合式API

    一文详解如何创建Vue3项目及组合式API

    Vue3提供了一种组合式API,可以用来构建可复用的组件和应用程序,下面这篇文章主要给大家介绍了关于如何创建Vue3项目及组合式API的相关资料,文中通过图文以及实例代码介绍的非常详细,需要的朋友可以参考下
    2023-05-05
  • vue项目history模式刷新404问题解决办法

    vue项目history模式刷新404问题解决办法

    这篇文章主要给大家介绍了关于vue项目history模式刷新404问题的解决办法,需要的朋友可以参考下
    2023-11-11
  • Vue3.0在组件外使用VueI18n的情况

    Vue3.0在组件外使用VueI18n的情况

    这篇文章主要介绍了Vue3.0在组件外使用VueI18n的情况,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2023-04-04
  • vue如何从接口请求数据

    vue如何从接口请求数据

    本篇文章主要介绍了vue如何从接口请求数据 ,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-06-06
  • 详解mpvue中小程序自定义导航组件开发指南

    详解mpvue中小程序自定义导航组件开发指南

    这篇笔记主要记录一下基于mpvue的小程序中实现自定义导航的思路及应用。小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2019-02-02
  • Vue3组合式函数Composable实战ref和unref使用

    Vue3组合式函数Composable实战ref和unref使用

    这篇文章主要为大家介绍了Vue3组合式函数Composable实战ref和unref使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪
    2023-06-06
  • Vue3发送post请求出现400 Bad Request报错的解决办法

    Vue3发送post请求出现400 Bad Request报错的解决办法

    这篇文章主要给大家介绍了关于Vue3发送post请求出现400 Bad Request报错的解决办法,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2023-02-02
  • laravel-admin 与 vue 结合使用实例代码详解

    laravel-admin 与 vue 结合使用实例代码详解

    由于 Laravel-admin 采用的是 pjax 的方式刷新页面,意味着很多页面刷新的操作,这篇文章主要介绍了laravel-admin 与 vue 结合使用,需要的朋友可以参考下
    2019-06-06

最新评论