国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

vue+Element中table表格實現可編輯(select下拉框)

瀏覽:18日期:2023-01-19 14:30:50

最近在工作中遇到一個問題,需要在表格中實現數據可編輯狀態,具體情況是需要在單元格里加入下拉框;并且每個下拉框的數組數據是不一樣的,具體是根據當前行前面數據的id查詢而來,前面的是數據是動態生成的,后面的下拉框數據也是根據id動態生成的,內容不同;有點類似于樹形二級狀態,后面的下拉框數據來源并沒有在前面內容里,而是另外一個接口查詢,具體操作如下:

vue+Element中table表格實現可編輯(select下拉框)

HTML代碼:

1.在處理人列加入一個下拉框模板,其中v-model必須要scope.row.proJbruserValue來綁定,意思是這個值綁定到當前行所選中的人;如果直接綁定proJbruserValue,將不能進行差異化選擇,(這里scope.row.proJbruserValue 相當于對象點屬性,在本地臨時添加了一個屬性來存儲不同行的選中處理人id)

2.通過點擊當前行下拉框獲取焦點,根據當前行id查詢對應的下拉框數據,并賦值給data中我們設置的數組接收,

3.一個重要的注意點,:key=item.id 這個key盡量綁定id,不推薦使用Index, 因為在這里使用Index的時候,會讓選中項出現數字bug,這是我在坑里呆了好久才通過我的一個朋友得到的答案,具體bug原因尚未深究,請重點注意;

4.最后點擊按鈕提交流程配置;

<el-table :data='processNodelist' border stripe> <el-table-column type='index' label='序號' width='50'></el-table-column> <el-table-column prop='nodename' label='流程節點名稱'></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: [], // 流程節點數據 projectJbrUserlist: [], // 處理人員數據 nodeidlist: [], // 所有流程節點Id selectedUserlist: [], // 被選中的處理人員id數組 }},created() { this.getProcessNodelist();},methods: { // 查詢流程節點數據 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(’獲取流程節點數據失敗’); } this.processNodelist = res.msg; }, // select下拉框獲取焦點的時候查詢id對應的下拉框數據源 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(’獲取處理人數據失敗’); } 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(’流程節點配置失敗’); } this.$message.success(’流程節點配置成功’); }, // 發起請求 submitConfigHandle() { // 循環流程節點數組將所有nodeid取出添加到新數組 for (let i = 0; i < this.processNodelist.length; i++) { this.nodeidlist.push(this.processNodelist[i].nodeid); } // 循環流程節點數組將所有被選擇的處理人員id :proJbruserValue取出添加到新數組 for (let i = 0; i < this.processNodelist.length; i++) { this.selectedUserlist.push( this.processNodelist[i].proJbruserValue ); } // 調用接口函數 this.submitConfig(); }}

這次實現表格可編輯功能(select下拉框),主要有兩個注意點,一是v-model的綁定問題,而是:key的綁定問題;這次我的數據接口是通過id返回的不同數據源,可以借鑒上面代碼,如果你的(select下拉框)數據源是多個接口查詢而來,你需要在通過接口查詢到各個數據源,保存到data里面,然后還要做一些改變:

1.將v-for循環的數據改成通過函數傳遞當前行數據(id):

<el-option v-for='item in getdatalist(scope.row) '> </el-option>

2.通過傳遞過來的id來判斷當前行需要返回的數據源;

getdatalist(row) { const id = row.nodeid; if ( id === ’1’) { return this.data1 } else if (id === ’2’) { return this.data2 }}

希望我的方法能給大家一些幫助和思路

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持好吧啦網。

標簽: Vue
相關文章:
主站蜘蛛池模板: 女人野外小树林一级毛片 | 国产com| 亚洲国产精品日韩在线 | 怡红院自拍 | 成人在免费视频手机观看网站 | 久草中文在线观看 | 亚洲国产日韩成人综合天堂 | 色综合亚洲七七久久桃花影院 | 一级毛片 在线播放 | 亚洲一区二区三区精品国产 | 男人操美女网站 | 免费a级在线观看播放 | 国产成人小视频在线观看 | 久久99国产乱子伦精品免费 | 玖草视频在线 | 秋霞手机入口二日韩区 | 精品一区二区三区在线视频 | 精品一久久香蕉国产二月 | 国产成人精品一区二区三区 | 日本一级高清片免费 | 亚洲国产精品成人午夜在线观看 | 日韩欧美一级毛片精品6 | 宅男66lu国产乱在线观看 | 国产欧美综合在线一区二区三区 | 男女福利社 | 免费在线观看一区 | 欧美亚洲日本国产 | 亚洲美女视频网站 | 亚洲天天 | 日本国产欧美色综合 | 欧美8888| 91九色国产| 久久久久久一级毛片免费野外 | 97国产大学生情侣11在线视频 | 国产精品李雅在线观看 | 91精品久久 | 男女男免费视频网站国产 | 欧美视频一区二区在线观看 | 五月色婷婷综合开心网4438 | 成年美女黄网站小视频 | 国产一级做a爰片... |