vue+element 模態(tài)框表格形式的可編輯表單實(shí)現(xiàn)
要實(shí)現(xiàn)的效果如下,初始化的時(shí)候,不可編輯,點(diǎn)擊編輯按鈕,編輯按鈕隱藏,取消編輯按鈕顯示;部分input輸入框變?yōu)榭删庉?br />


<el-dialog title="營(yíng)銷單詳情" width="920px" @close="isEdit = false" class="dialog dialogAdd" custom-class="custom-dialog"
:visible.sync="dialogEditVisible" :close-on-click-modal='false'>
<el-form ref="editForm" style="margin-right: 20px;" :model="editForm" :inline="true" label-position="right" label-width="110px" size="mini">
<el-form-item label="工單號(hào)" prop="no">
<el-input v-model="editForm.no" disabled></el-input>
</el-form-item>
<el-form-item label="客戶姓名" prop="khxm">
<el-input v-model="editForm.khxm" :disabled="!isEdit || editForm.openId"></el-input>
</el-form-item>
<el-form-item label="聯(lián)系電話" prop="khdh">
<el-input v-model="editForm.khdh" :disabled="!isEdit || editForm.openId"></el-input>
</el-form-item>
<el-form-item label="客戶地址">
<el-input v-model="editForm.address" disabled></el-input>
</el-form-item>
<el-form-item label="營(yíng)銷人員-工號(hào)">
<el-input v-model="editForm.yxry" disabled></el-input>
</el-form-item>
<el-form-item label="網(wǎng)格區(qū)域">
<el-input v-model="editForm.qywg" disabled></el-input>
</el-form-item>
<el-form-item label="業(yè)務(wù)類型" prop="ywlx">
<el-select v-model="editForm.ywlx" :disabled="!isEdit" placeholder="">
<el-option v-for="item in ywlxList" :key="item" :label="item" :value="item"></el-option>
</el-select>
</el-form-item>
<el-form-item label="報(bào)裝寬帶兆數(shù)(M)" prop="kdzs" class="long-label">
<el-select v-model="editForm.kdzs" :disabled="!isEdit" placeholder="">
<el-option v-for="item in kdzsList" :key="item" :label="item" :value="item"></el-option>
</el-select>
</el-form-item>
<el-form-item label="手機(jī)基礎(chǔ)套餐(最低消費(fèi))" class="long-label" prop="sjjctc" >
<el-select v-model="editForm.sjjctc" :disabled="!isEdit" placeholder="">
<el-option v-for="item in sjtcList" :key="item" :label="item" :value="item"></el-option>
</el-select>
</el-form-item>
<el-form-item label="業(yè)務(wù)受理單截屏">
<p><a class="text-base" @click="show">查看圖片</a></p>
</el-form-item>
<el-form-item label="下單時(shí)間" 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中的數(shù)據(jù)
editForm: {}, // 新增表單
isEdit: false, // 是否編輯
dialogEditVisible: false, // 新增模態(tài)框
images: [], // 圖片信息
ywlxList: [], // 業(yè)務(wù)類型列表
kdzsList: ['50', '100', '200', '300'], // 報(bào)裝寬帶兆數(shù)列表
sjtcList: ['38', '58', '88', '98', '128', '138', '188'], // 手機(jī)基礎(chǔ)套餐列表
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("暫無(wú)圖片")
return
}
this.$viewer.show()
},
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Vue.js彈出模態(tài)框組件開(kāi)發(fā)的示例代碼
- 利用vue實(shí)現(xiàn)模態(tài)框組件
- vue+element模態(tài)框中新增模態(tài)框和刪除功能
- vue實(shí)現(xiàn)模態(tài)框的通用寫(xiě)法推薦
- vue.extend實(shí)現(xiàn)alert模態(tài)框彈窗組件
- 詳解如何用VUE寫(xiě)一個(gè)多用模態(tài)框組件模版
- vue移動(dòng)端模態(tài)框(可傳參)的實(shí)現(xiàn)
- 詳解vue父子組件關(guān)于模態(tài)框狀態(tài)的綁定方案
- Vue.extend 登錄注冊(cè)模態(tài)框的實(shí)現(xiàn)
- Vue?dialog模態(tài)框的封裝方法
相關(guān)文章
vue實(shí)現(xiàn)綁定事件的方法實(shí)例代碼詳解
這篇文章主要介紹了vue實(shí)現(xiàn)綁定事件的方法實(shí)例代碼,非常不錯(cuò),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2019-06-06
vue項(xiàng)目如何使用three.js實(shí)現(xiàn)vr360度全景圖片預(yù)覽
這篇文章主要介紹了vue項(xiàng)目如何使用three.js實(shí)現(xiàn)vr360度全景圖片預(yù)覽,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-03-03
基于vue2實(shí)現(xiàn)簡(jiǎn)單的答題組件
這篇文章主要為大家詳細(xì)介紹了如何基于vue2實(shí)現(xiàn)簡(jiǎn)單的答題組件,點(diǎn)擊正確的選項(xiàng),該選項(xiàng)背景變綠色;點(diǎn)擊錯(cuò)誤的選項(xiàng),該選項(xiàng)背景變紅色,有需要的可以參考下2024-12-12
vue 重塑數(shù)組之修改數(shù)組指定index的值操作
這篇文章主要介紹了vue 重塑數(shù)組之修改數(shù)組指定index的值操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-08-08
Vue項(xiàng)目獲取url中的參數(shù)(親測(cè)可用)
這篇文章主要介紹了Vue項(xiàng)目獲取url中的參數(shù),本文通過(guò)兩種情況分析給大家詳細(xì)介紹,感興趣的朋友一起看看吧2022-08-08
vue3如何使用provide實(shí)現(xiàn)狀態(tài)管理詳解
Vue3中有一對(duì)新增的api,provide和inject,熟悉Vue2的朋友應(yīng)該明,這篇文章主要給大家介紹了關(guān)于vue3如何使用provide實(shí)現(xiàn)狀態(tài)管理的相關(guān)資料,需要的朋友可以參考下2021-10-10
vue 計(jì)算屬性和偵聽(tīng)器的使用小結(jié)
這篇文章主要介紹了vue 計(jì)算屬性和偵聽(tīng)器的使用小結(jié),幫助大家更好的理解和使用vue框架,感興趣的朋友可以了解下2021-01-01

