基于elementUI实现一个可编辑的表格(简洁版)

需求:

实现一个可编辑、增加、删除的表格,每一项是可编辑的输入框、

注:使用vue3+elementui

实现

1、dom部分

html 复制代码
<el-form :model="formData" ref="formRef">
                <el-table :data="filteredTableData" border fit max-height="800">
                <el-table-column label="序号" width="100" align="center">
                    <template #default="{ $index }">
                        {{ $index + 1 }}
                    </template>
                </el-table-column>
                <el-table-column label="手机号" align="center">
                    <template #default="{ row, $index }">
                    <el-form-item
                        :prop="`tableData.${$index}.phone_num`"
                        :rules="phoneRules"
                    >
                        <el-input v-model="row.phone_num" placeholder="请输入手机号" />
                    </el-form-item>
                    </template>
                </el-table-column>
                <el-table-column label="年龄" align="center">
                    <template #default="{ row, $index }">
                    <el-form-item
                        :prop="`tableData.${$index}.car_plate_num`"
                        :rules="plateRules"
                    >
                        <el-input v-model="row.car_plate_num" placeholder="请输入年龄" />
                    </el-form-item>
                    </template>
                </el-table-column>
                <el-table-column label="身高" align="center">
                    <template #default="{ row, $index }">
                    <el-form-item
                        :prop="`tableData.${$index}.vin`"
                        :rules="vinRules"
                    >
                        <el-input v-model="row.vin" placeholder="请输入身高" />
                    </el-form-item>
                    </template>
                </el-table-column>
                <!-- 操作列 -->
                <el-table-column label="操作" align="center" width="100">
                    <template #default="{ row, $index }">
                        <el-icon color="#f56c6c" @click="deleteFilteredRow($index)"><Delete /></el-icon>
                    </template>
                </el-table-column>
                </el-table>
                <el-button style="margin-top:10px" type="primary" plain @click="addRow">+ 添加</el-button>
            </el-form>

2、js部分

javascript 复制代码
// 搜索相关变量
const searchPhone = ref('')
const filteredTableData = ref([])
const originalTableData = ref([])
const tableData = ref<ChargeConfig[]>([]);
// 表单数据
const formData = reactive({
  tableData: [
    { phone_num: '', car_plate_num: '', vin: '' },
  ],
})
const formRef = ref<FormInstance>()
// 表单校验部分
const phoneRules = [{ required: true, message: '请输入手机号', trigger: 'blur' }, { pattern: /^1[3-9]\d{9}$/, message: '请输入11位手机号', trigger: 'blur' }]
const plateRules = [{ required: true, message: '请输入年龄', trigger: 'blur' }]
const vinRules = [{ required: true, message: '请输入身高', trigger: 'blur' }]

// 表单数据
const formData = reactive({
  tableData: [
    { phone_num: '', car_plate_num: '', vin: '' },
  ],
})
const formRef = ref<FormInstance>()
const whiteListVisible = ref(false)

// 手机号搜索方法
const handlePhoneSearch = () => {
    const keyword = searchPhone.value.trim()
    if (!keyword) {
        filteredTableData.value = [...formData.tableData]
    } else {
        filteredTableData.value = formData.tableData.filter(item => 
            item.phone_num && item.phone_num.includes(keyword)
        )
    }
}
// 重置搜索
const resetPhoneSearch = () => {
    searchPhone.value = ''
    filteredTableData.value = [...formData.tableData]
}
// 删除行
const deleteFilteredRow = (index: number) => {
    const deletedItem = filteredTableData.value[index]
    
    // 从原始数据中删除
    const originalIndex = formData.tableData.findIndex(item => 
        item.phone_num === deletedItem.phone_num && 
        item.car_plate_num === deletedItem.car_plate_num && 
        item.vin === deletedItem.vin
    )
    
    if (originalIndex > -1) {
        formData.tableData.splice(originalIndex, 1)
    }
    // 更新过滤后的数据
    handlePhoneSearch()
}
// 添加行
const addRow = () => {
    resetPhoneSearch()
    const newRow = { phone_num: '', car_plate_num: '', vin: '' }
    formData.tableData.push(newRow)
    handlePhoneSearch()
}
// 保存
const saveList = () => {
    // 校验一下表单填写
    formRef.value.validate(valid => {
		if (!valid){
            ElMessage.error("请填写表");
            return;
        }
        // 校验成功,调用接口保存操作
    }).catch(() => {
        ElMessage.error("校验失败,请刷新重试");
    })
}

3.css部分

这里主要是调整一下表格内输入框的位置(看你自己需要,可不用)

scss 复制代码
<style scoped>
:deep(.el-table .cell) {
  padding-top: 12px!important;
}
</style>

end~

希望记录的问题能帮助到你!

相关推荐
郝学胜-神的一滴1 分钟前
Cesium绘制线:从基础到高级技巧
前端·javascript·程序人生·线性代数·算法·矩阵·图形渲染
蒙奇D索大32 分钟前
【计算机网络】408计算机网络高分指南:物理层编码与调制技术精讲
java·前端·学习·计算机网络
无盐海42 分钟前
CSRF漏洞攻击(跨站请求伪造攻击)
前端·csrf
慧一居士1 小时前
CSS3 全部功能点介绍,使用场景,对应功能点完整使用示例
前端
烛阴1 小时前
深入Lua包(Package)与依赖管理
前端·lua
IT_陈寒1 小时前
5个Vue3性能优化技巧,让你的应用提速50% 🚀(附实测对比)
前端·人工智能·后端
god001 小时前
chromium项目中添加源文件(BUILD.gn项目中添加源文件)
java·服务器·前端
快乐非自愿1 小时前
Vue 缓存之坑,变量赋值方式和响应式数据
前端·vue.js·缓存
Github掘金计划1 小时前
别再用 “臃肿监控” 了!这款轻量监控神器开源 3 月狂揽 1.3k Star!
前端·监控
努力学习的少女1 小时前
SpaekSql函数
前端·数据库