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,7 +173,8 @@ | ||
173 | bodyHeight: 0, | 173 | bodyHeight: 0, |
174 | bodyRealHeight: 0, | 174 | bodyRealHeight: 0, |
175 | scrollBarWidth: getScrollBarSize(), | 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 | computed: { | 180 | computed: { |
@@ -357,16 +358,16 @@ | @@ -357,16 +358,16 @@ | ||
357 | } | 358 | } |
358 | } | 359 | } |
359 | this.objData[_index]._isHighlight = true; | 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 | clickCurrentRow (_index) { | 364 | clickCurrentRow (_index) { |
364 | this.highlightCurrentRow (_index); | 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 | dblclickCurrentRow (_index) { | 368 | dblclickCurrentRow (_index) { |
368 | this.highlightCurrentRow (_index); | 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 | getSelection () { | 372 | getSelection () { |
372 | let selectionIndexes = []; | 373 | let selectionIndexes = []; |
@@ -663,6 +664,10 @@ | @@ -663,6 +664,10 @@ | ||
663 | this.objData = this.makeObjData(); | 664 | this.objData = this.makeObjData(); |
664 | this.rebuildData = this.makeDataWithSortAndFilter(); | 665 | this.rebuildData = this.makeDataWithSortAndFilter(); |
665 | this.handleResize(); | 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 | deep: true | 672 | deep: true |
668 | }, | 673 | }, |