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()
}
}总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Vue3组合式函数Composable实战ref和unref使用
这篇文章主要为大家介绍了Vue3组合式函数Composable实战ref和unref使用详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2023-06-06
Vue3发送post请求出现400 Bad Request报错的解决办法
这篇文章主要给大家介绍了关于Vue3发送post请求出现400 Bad Request报错的解决办法,文中通过实例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下2023-02-02
laravel-admin 与 vue 结合使用实例代码详解
由于 Laravel-admin 采用的是 pjax 的方式刷新页面,意味着很多页面刷新的操作,这篇文章主要介绍了laravel-admin 与 vue 结合使用,需要的朋友可以参考下2019-06-06


最新评论