vue+element-ui 修改動態生成的表格(el-table)中的資料
客戶又提需求了(/微笑)
不管需求是啥,為難我就是無理取鬧,哼!
原本就是動態生成的el-table表格,裡面的資料還要修改。意味著要修改的欄位名都是動態的,我需要動態的宣告input框繫結的變數,其實本來以為就那麼回事兒,就跟以前做得差不了太多,結果搞了一天!!!雖然是實現了,但至今沒弄明白我遇到的問題是怎麼肥四。
<!--顯示資料表格-->
<div class="table_common_container lsz_content-load active-table" style="height: 100%">
<el-table v-show="show_table" border :data="data_list" v-loading="loading" element-loading-text="loading" @selection-change="handleSelect" height="100%" >
<el-table-column prop="selected" type="selection" width="40" v-model="multipleSelection">
</el-table-column>
<el-table-column v-for="(item,index) in table_labels" :label="item" width="200" :prop="table_props[index]" :key="index" show-overflow-tooltip></el-table-column>
</el-table>
<el-table v-show="!show_table" border :data="null_arr" v-loading="loading" element-loading-text="loading" height="100%" >
<el-table-column v-for="(item,index) in null_arr" :label="item" width="200" :prop="table_props[index]" :key="index" show-overflow-tooltip></el-table-column>
</el-table>
</div>
<!--編輯彈框-->
<el-dialog :title="$t('search_data.action.update')" v-if="is_change_data" :visible.sync="is_change_data" width="450px">
<div>
<el-form :model="change_data" ref="change_data" label-width="120px" :rules="rules">
<el-form-item v-for="(item,index) in table_labels" :key="index" :label="item" prop="type_code" style="width: 95%;display: inline-block;" >
<el-input v-model="cloneMultipleSelection[0][change_props[index]]"
autocomplete="off"></el-input>
</el-form-item>
</el-form>
</div>
<span slot="footer" class="dialog-footer">
<el-button type="primary" @click="confirmChange">{{$t('button.confirm')}}</el-button>
<el-button @click="reset(change_data)">{{$t('button.cancel')}}</el-button>
</span>
</el-dialog>
用了el-table自帶的CheckBox來實現選中表格中的資料進而實現修改。
將選中的行的資料存入multipleSelection(是一個物件陣列)
原本想像之前專案中實現修改一樣,將修改的資料繫結在一個物件change_data中,然後change_data先賦值為multipleSelection[0]裡相應的值,我甚至用了深拷貝先將multipleSelection賦值給另一個變數cloneMultipleSelection,為了在修改的時候不會影響multipleSelection,但我發現事情並沒有那麼簡單。
//這裡是給編輯頁面獲取原始值的程式碼
this.is_change_data=true
this.cloneMultipleSelection=this.deepClone(this.multipleSelection)
this.change_props=this.deepClone(this.table_props)
console.log(this.cloneMultipleSelection[0])
for(let item in this.cloneMultipleSelection[0]){
this.change_data[item]=this.cloneMultipleSelection[0][item]
//深拷貝方法
deepClone(obj){
var o;
// 如果 他是物件object的話 , 因為null,object,array 也是'object';
if (typeof obj === 'object') {
// 如果 他是空的話
if (obj === null) {
o = null;
} else {
// 如果 他是陣列arr的話
//console.log(obj instanceof Array)
if (obj instanceof Array) {
o = [];
for (var i = 0, len = obj.length; i < len; i++) {
o.push(this.deepClone(obj[ i ]));
}
} else { // 如果 他是物件object的話
o = {};
for (var j in obj) {
o[ j ] = this.deepClone(obj[ j ]);
}
}
}
} else {
o = obj;
}
return o;
},
<el-dialog :title="$t('search_data.action.update')" v-if="is_change_data" :visible.sync="is_change_data" width="450px">
<!--我只要在這裡不加v-if,資料表格就無法正常顯示資料。我的資料顯示都是之前做得妥妥的,沒任何毛病-->
<el-form-item v-for="(item,index) in table_labels" :key="index" :label="item" prop="type_code" style="width: 95%;display: inline-block;" >
<el-input v-model="cloneMultipleSelection[0][change_props[index]]" autocomplete="off"></el-input>
</el-form-item>
<!--然後這裡v-model改為v-model="change_data[change_props[index]]"表格就可以正常顯示資料,但是!!!修改資料的時候,input框的值不能修改!人間迷惑-->
然後el-dialog的顯示隱藏好像必須要通過:visible.sync來實現,所以我用了v-if,還用了:visible.sync
相關文章
- vue + element UI 中 el-table 資料匯出Excel表格VueUIExcel
- Django中的ORM如何通過資料庫中的表格資訊自動化生成Model 模型類?DjangoORM資料庫模型
- vue - elementui 元件 表格 <el-table> 列頭修改背景顏色VueUI元件
- PHP--動態生成sql查詢表格PHPSQL
- 聊聊 Vue 中 title 的動態修改Vue
- element-plus 如何修改el-table 捲軸高度,el-table捲軸放置在表格外面
- mysql 動態生成測試資料MySql
- JavaScript動態建立表格和增加表格的行JavaScript
- elementui表格動態資料單元格合併UI
- Python資料展示 - 生成表格圖片Python
- vue+element-ui中獲取頁面資料VueUI
- 如何在iView中動態建立表格View
- vue中動態修改陣列的展現(資料更新,檢視不更新驗證)Vue陣列
- vue中echarts的動態渲染資料watchVueEcharts
- 兩種動態建立表格的方法
- el-table 合併相同資料的列
- el-table合併相同資料的行
- vue+element-ui el-table元件內表單驗證問題VueUI元件
- SVG 在 image 標籤中的動態修改技巧SVG
- python修改運動資料的方法Python
- vue+element-ui實現動態的許可權管理和選單渲染VueUI
- el-table 多表格彈窗巢狀資料顯示異常錯亂問題巢狀
- vue+elementUI el-table匯出excel表格VueUIExcel
- 基於結構化資料的文字生成:非嚴格對齊生成任務及動態輕量的GCN生成模型GC模型
- element-ui中的table表格修改背景樣式透明UI
- 好用漂亮的Android 表格框架4(自動生成表單)Android框架
- 航圖中的扇區資料生成
- 動態庫的生成和使用(二)
- JavaScript動態建立table表格JavaScript
- 淺談資料的表格化
- Java反射動態修改註解的值Java反射
- MySQL動態修改varchar長度的方法MySql
- 【Vue】el-table 簡易表格可篩選列Vue
- ANT 的Table表格樣式修改方法
- 動態修改Shape的solid屬性的color值Solid
- Layui 表格資料修改成功後重新整理顯示UI
- 我應該手動修改線上資料庫的資料嗎?資料庫
- 生成表格與合併表格