vue+element 模态框表格形式的可编辑表单实现

2020-06-14 06:08:15易采站长站整理

</el-form-item>
<el-form-item label="下单时间" prop="createTime" >
<el-input v-model="editForm.createTime" disabled></el-input>
</el-form-item>
<el-form-item label="备注" prop="remark">
<el-input v-model="editForm.remark" :disabled="!isEdit"></el-input>
</el-form-item>
</el-form>

<div slot="footer" class="dialog-footer" v-if="editForm.state != 3">
<el-button v-if="!isEdit" @click="isEdit = true" size="mini">编 辑</el-button>
<el-button v-else @click="cancelEdit" size="mini">取消编辑</el-button>
<el-button type="primary" @click="saveEdit" size="mini">保 存</el-button>
</div>
</el-dialog>

data中的数据


editForm: {}, // 新增表单
isEdit: false, // 是否编辑
dialogEditVisible: false, // 新增模态框
images: [], // 图片信息
ywlxList: [], // 业务类型列表
kdzsList: ['50', '100', '200', '300'], // 报装宽带兆数列表
sjtcList: ['38', '58', '88', '98', '128', '138', '188'], // 手机基础套餐列表


viewDetail(row){
console.log(row)
this.editForm = this.deepClone(row)
this.dialogEditVisible = true
this.$post("/anapi/YxdController/getById", {id: row.id}, (data) => {
this.editForm = data.yxd
this.editForm.qywg = row.name1 + row.name2 + row.name3 + row.gridName
this.editForm.address = row.name1 + row.name2 + row.name3 + row.gridName + row.xxdz
this.editForm.yxry = row.yxCname + '-' + row.yxId
this.currentItem = this.deepClone(this.editForm)

let imgs = data.yxd.imgs || [] this.images = [] imgs.map(item => {
this.images.push(this.config.httpHeadUrl + item)
})
})
},
// 保存编辑
saveEdit(){
this.$refs.editForm.validate((valid) => {
if (valid) {
this.startLoading()
this.$post("/api/YxdController/editYxd", this.editForm, (data) => {
this.$message.success("修改成功!")
this.dialogEditVisible = false
this.getTableData(1)
})
}
})
},
// 取消编辑
cancelEdit(){
this.isEdit = false
this.editForm = this.deepClone(this.currentItem)
},

// 查看图片
inited (viewer) {
this.$viewer = viewer
},
show () {
if(!this.images.length){
this.$message.error("暂无图片")
return
}
this.$viewer.show()
},