Commit 63f2e0f4c4bb15b08ac91f1490adfa5cd14cdf41
1 parent
99d0429e
fixed Table bug when remove a row of data
when Cell has a button to delete row data, clickCurrentRow will throw an error, so clone a data
Showing
1 changed file
with
10 additions
and
5 deletions
Show diff stats
src/components/table/table.vue
... | ... | @@ -173,7 +173,8 @@ |
173 | 173 | bodyHeight: 0, |
174 | 174 | bodyRealHeight: 0, |
175 | 175 | scrollBarWidth: getScrollBarSize(), |
176 | - currentContent: this.content | |
176 | + currentContent: this.content, | |
177 | + cloneData: deepCopy(this.data) // when Cell has a button to delete row data, clickCurrentRow will throw an error, so clone a data | |
177 | 178 | }; |
178 | 179 | }, |
179 | 180 | computed: { |
... | ... | @@ -357,16 +358,16 @@ |
357 | 358 | } |
358 | 359 | } |
359 | 360 | this.objData[_index]._isHighlight = true; |
360 | - const oldData = oldIndex < 0 ? null : JSON.parse(JSON.stringify(this.data[oldIndex])); | |
361 | - this.$emit('on-current-change', JSON.parse(JSON.stringify(this.data[_index])), oldData); | |
361 | + const oldData = oldIndex < 0 ? null : JSON.parse(JSON.stringify(this.cloneData[oldIndex])); | |
362 | + this.$emit('on-current-change', JSON.parse(JSON.stringify(this.cloneData[_index])), oldData); | |
362 | 363 | }, |
363 | 364 | clickCurrentRow (_index) { |
364 | 365 | this.highlightCurrentRow (_index); |
365 | - this.$emit('on-row-click', JSON.parse(JSON.stringify(this.data[_index]))); | |
366 | + this.$emit('on-row-click', JSON.parse(JSON.stringify(this.cloneData[_index]))); | |
366 | 367 | }, |
367 | 368 | dblclickCurrentRow (_index) { |
368 | 369 | this.highlightCurrentRow (_index); |
369 | - this.$emit('on-row-dblclick', JSON.parse(JSON.stringify(this.data[_index]))); | |
370 | + this.$emit('on-row-dblclick', JSON.parse(JSON.stringify(this.cloneData[_index]))); | |
370 | 371 | }, |
371 | 372 | getSelection () { |
372 | 373 | let selectionIndexes = []; |
... | ... | @@ -663,6 +664,10 @@ |
663 | 664 | this.objData = this.makeObjData(); |
664 | 665 | this.rebuildData = this.makeDataWithSortAndFilter(); |
665 | 666 | this.handleResize(); |
667 | + // here will trigger before clickCurrentRow, so use async | |
668 | + setTimeout(() => { | |
669 | + this.cloneData = deepCopy(this.data); | |
670 | + }, 0); | |
666 | 671 | }, |
667 | 672 | deep: true |
668 | 673 | }, | ... | ... |