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 | }, |