vue+Element中table表格實現(xiàn)可編輯(select下拉框)
最近在工作中遇到一個問題,需要在表格中實現(xiàn)數(shù)據(jù)可編輯狀態(tài),具體情況是需要在單元格里加入下拉框;并且每個下拉框的數(shù)組數(shù)據(jù)是不一樣的,具體是根據(jù)當(dāng)前行前面數(shù)據(jù)的id查詢而來,前面的是數(shù)據(jù)是動態(tài)生成的,后面的下拉框數(shù)據(jù)也是根據(jù)id動態(tài)生成的,內(nèi)容不同;有點(diǎn)類似于樹形二級狀態(tài),后面的下拉框數(shù)據(jù)來源并沒有在前面內(nèi)容里,而是另外一個接口查詢,具體操作如下:

HTML代碼:
1.在處理人列加入一個下拉框模板,其中v-model必須要scope.row.proJbruserValue來綁定,意思是這個值綁定到當(dāng)前行所選中的人;如果直接綁定proJbruserValue,將不能進(jìn)行差異化選擇,(這里scope.row.proJbruserValue 相當(dāng)于對象點(diǎn)屬性,在本地臨時添加了一個屬性來存儲不同行的選中處理人id)
2.通過點(diǎn)擊當(dāng)前行下拉框獲取焦點(diǎn),根據(jù)當(dāng)前行id查詢對應(yīng)的下拉框數(shù)據(jù),并賦值給data中我們設(shè)置的數(shù)組接收,
3.一個重要的注意點(diǎn),:key=item.id 這個key盡量綁定id,不推薦使用Index, 因為在這里使用Index的時候,會讓選中項出現(xiàn)數(shù)字bug,這是我在坑里呆了好久才通過我的一個朋友得到的答案,具體bug原因尚未深究,請重點(diǎn)注意;
4.最后點(diǎn)擊按鈕提交流程配置;
<el-table :data="processNodelist" style="width: 100%" border stripe> <el-table-column type="index" label="序號" width="50"></el-table-column> <el-table-column prop="nodename" label="流程節(jié)點(diǎn)名稱"></el-table-column> <el-table-column label="處理人名稱"> <template slot-scope="scope"> <el-select v-model="scope.row.proJbruserValue" @focus="getDatalist(scope.row)" placeholder="請選擇" filterable allow-create> <el-option v-for="item in projectJbrUserlist " :key="item.id" :label="item.username" :value="item.id"> </el-option> </el-select> </template> </el-table-column> </el-table> <el-button @click="submitConfigHandle" type="primary" size="mini" icon="el-icon-upload">提交配置</el-button>
js邏輯代碼:
data() {
return {
processNodelist: [], // 流程節(jié)點(diǎn)數(shù)據(jù)
projectJbrUserlist: [], // 處理人員數(shù)據(jù)
nodeidlist: [], // 所有流程節(jié)點(diǎn)Id
selectedUserlist: [], // 被選中的處理人員id數(shù)組
}
},
created() {
this.getProcessNodelist();
},
methods: {
// 查詢流程節(jié)點(diǎn)數(shù)據(jù)
async getProcessNodelist() {
const { data: res } = await this.$http.post('querynode', {
userid: this.sessionInfo.userid,
sid: this.sessionInfo.session,
developerid: this.sessionInfo.companyId
});
if (res.code !== 0) {
return this.$message.error('獲取流程節(jié)點(diǎn)數(shù)據(jù)失敗');
}
this.processNodelist = res.msg;
},
// select下拉框獲取焦點(diǎn)的時候查詢id對應(yīng)的下拉框數(shù)據(jù)源
async getDatalist(row) {
const { data: res } = await this.$http.post('query', {
userid: this.sessionInfo.userid,
sid: this.sessionInfo.session,
queryid: 9,
nodeid: row.nodeid
});
if (res.code !== 0) {
return this.$message.error('獲取處理人數(shù)據(jù)失敗');
}
this.projectJbrUserlist = res.msg;
},
// 提交流程配置接口
async submitConfig() {
const { data: res } = await this.$http.post('bindTask', {
userid: this.sessionInfo.userid,
sid: this.sessionInfo.session,
flowid: 9,
table_name: 'pt_base',
key_value: this.sessionInfo.proId,
nodeid: this.nodeidlist,
uid: this.selectedUserlist
});
if (res.code !== 0) {
return this.$message.error('流程節(jié)點(diǎn)配置失敗');
}
this.$message.success('流程節(jié)點(diǎn)配置成功');
},
// 發(fā)起請求
submitConfigHandle() {
// 循環(huán)流程節(jié)點(diǎn)數(shù)組將所有nodeid取出添加到新數(shù)組
for (let i = 0; i < this.processNodelist.length; i++) {
this.nodeidlist.push(this.processNodelist[i].nodeid);
}
// 循環(huán)流程節(jié)點(diǎn)數(shù)組將所有被選擇的處理人員id :proJbruserValue取出添加到新數(shù)組
for (let i = 0; i < this.processNodelist.length; i++) {
this.selectedUserlist.push(
this.processNodelist[i].proJbruserValue
);
}
// 調(diào)用接口函數(shù)
this.submitConfig();
}
}這次實現(xiàn)表格可編輯功能(select下拉框),主要有兩個注意點(diǎn),一是v-model的綁定問題,而是:key的綁定問題;這次我的數(shù)據(jù)接口是通過id返回的不同數(shù)據(jù)源,可以借鑒上面代碼,如果你的(select下拉框)數(shù)據(jù)源是多個接口查詢而來,你需要在通過接口查詢到各個數(shù)據(jù)源,保存到data里面,然后還要做一些改變:
1.將v-for循環(huán)的數(shù)據(jù)改成通過函數(shù)傳遞當(dāng)前行數(shù)據(jù)(id):
<el-option v-for="item in getdatalist(scope.row) "> </el-option>
2.通過傳遞過來的id來判斷當(dāng)前行需要返回的數(shù)據(jù)源;
getdatalist(row) {
const id = row.nodeid;
if ( id === '1') {
return this.data1
} else if (id === '2') {
return this.data2
}
}希望我的方法能給大家一些幫助和思路
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
vue項目使用定時器每隔幾秒運(yùn)行一次某方法代碼實例
有時候在項目中我們經(jīng)常需要設(shè)置簡單的倒計時功能,這個可以通過定時器來實現(xiàn),下面這篇文章主要給大家介紹了關(guān)于vue項目使用定時器每隔幾秒運(yùn)行一次某方法的相關(guān)資料,需要的朋友可以參考下2023-04-04
npm run serve運(yùn)行vue項目時報錯:Error: error:0308010C
這篇文章主要介紹了npm run serve運(yùn)行vue項目時,出現(xiàn)報錯:Error: error:0308010C:digital envelope routines::unsupported的解決方法,文中有詳細(xì)的解決方法,需要的朋友可以參考下2024-04-04
Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別詳解
vue-cli是Vue早期推出的一款腳手架,使用webpack創(chuàng)建Vue項目,可以選擇安裝需要的各種插件,比如Vuex、VueRouter,下面這篇文章主要給大家介紹了關(guān)于Vue3中Vite和Vue-cli的特點(diǎn)與區(qū)別的相關(guān)資料,需要的朋友可以參考下2022-12-12
element-ui 插槽自定義樣式居中效果實現(xiàn)思路
這篇文章主要介紹了element-ui 插槽自定義樣式居中效果,簡單來講實現(xiàn)思路是通過template標(biāo)簽可理解為一個內(nèi)嵌組件,寬高重新定義,可在自定義內(nèi)容外層套一層盒子,讓盒子占滿所有空間,再使用flex讓內(nèi)部元素居中,需要的朋友可以參考下2024-07-07
vue在自定義組件中使用v-model進(jìn)行數(shù)據(jù)綁定的方法
這篇文章主要介紹了vue在自定義組件中使用v-model進(jìn)行數(shù)據(jù)綁定的方法,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-03-03
Vue組件通信中非父子組件傳值知識點(diǎn)總結(jié)
在本篇文章里小編給大家整理的是關(guān)于Vue組件通信中非父子組件傳值知識點(diǎn)總結(jié),有興趣的朋友們學(xué)習(xí)下。2019-12-12
vue頭部導(dǎo)航動態(tài)點(diǎn)擊處理方法
這篇文章主要介紹了vue頭部導(dǎo)航動態(tài)點(diǎn)擊處理方法,文中通過一段示例代碼給大家介紹了vue實現(xiàn)動態(tài)頭部的方法,需要的朋友可以參考下2018-11-11
Vue網(wǎng)頁html轉(zhuǎn)換PDF(最低兼容ie10)的思路詳解
這篇文章主要介紹了Vue網(wǎng)頁html轉(zhuǎn)換PDF(最低兼容ie10)的思路詳解,實現(xiàn)此功能需要引入兩個插件,需要的朋友可以參考下2017-08-08

