Commit d87ce40a740534e9876c228be2fcfebb1e902af3
1 parent
6f8608bb
update Select
Showing
2 changed files
with
26 additions
and
10 deletions
Show diff stats
examples/routers/select.vue
1 | <template> | 1 | <template> |
2 | - <div style="width: 200px;margin: 100px;"> | ||
3 | - {{ model }} | ||
4 | - <i-select v-model="model" filterable remote :remote-method="remoteMethod" :loading="loading" clearable style="width:200px"> | ||
5 | - <i-option v-for="option in options" :value="option.value" :key="option">{{option.label}}</i-option> | ||
6 | - </i-select> | ||
7 | - <!--<Button @click="handleAdd">+</Button>--> | ||
8 | - </div> | 2 | + <Row> |
3 | + <i-col span="4">{{model}}</i-col> | ||
4 | + <i-col span="8"> | ||
5 | + <i-select v-model="model" multiple filterable remote :remote-method="remoteMethod" :loading="loading" clearable> | ||
6 | + <i-option v-for="option in options" :value="option.value" :key="option">{{option.label}}</i-option> | ||
7 | + </i-select> | ||
8 | + </i-col> | ||
9 | + </Row> | ||
9 | </template> | 10 | </template> |
10 | 11 | ||
11 | <script> | 12 | <script> |
12 | export default { | 13 | export default { |
13 | data () { | 14 | data () { |
14 | return { | 15 | return { |
15 | - model: '', | 16 | + model: [], |
16 | options: [ | 17 | options: [ |
17 | 18 | ||
18 | ], | 19 | ], |
src/components/select/select.vue
@@ -300,7 +300,7 @@ | @@ -300,7 +300,7 @@ | ||
300 | }, | 300 | }, |
301 | updateMultipleSelected (init = false, slot = false) { | 301 | updateMultipleSelected (init = false, slot = false) { |
302 | if (this.multiple && Array.isArray(this.model)) { | 302 | if (this.multiple && Array.isArray(this.model)) { |
303 | - let selected = []; | 303 | + let selected = this.remote ? this.selectedMultiple : []; |
304 | 304 | ||
305 | for (let i = 0; i < this.model.length; i++) { | 305 | for (let i = 0; i < this.model.length; i++) { |
306 | const model = this.model[i]; | 306 | const model = this.model[i]; |
@@ -317,7 +317,16 @@ | @@ -317,7 +317,16 @@ | ||
317 | } | 317 | } |
318 | } | 318 | } |
319 | 319 | ||
320 | - this.selectedMultiple = selected; | 320 | + const selectedArray = []; |
321 | + const selectedObject = {}; | ||
322 | + selected.forEach(item => { | ||
323 | + if (!selectedObject[item.value]) { | ||
324 | + selectedArray.push(item); | ||
325 | + selectedObject[item.value] = 1; | ||
326 | + } | ||
327 | + }); | ||
328 | + | ||
329 | + this.selectedMultiple = this.remote ? selectedArray : selected; | ||
321 | 330 | ||
322 | if (slot) { | 331 | if (slot) { |
323 | let selectedModel = []; | 332 | let selectedModel = []; |
@@ -340,6 +349,12 @@ | @@ -340,6 +349,12 @@ | ||
340 | if (this.disabled) { | 349 | if (this.disabled) { |
341 | return false; | 350 | return false; |
342 | } | 351 | } |
352 | + | ||
353 | + if (this.remote) { | ||
354 | + const tag = this.model[index]; | ||
355 | + this.selectedMultiple = this.selectedMultiple.filter(item => item.value !== tag); | ||
356 | + } | ||
357 | + | ||
343 | this.model.splice(index, 1); | 358 | this.model.splice(index, 1); |
344 | 359 | ||
345 | if (this.filterable && this.visible) { | 360 | if (this.filterable && this.visible) { |