optimize Select event broadcast
optimize Select event broadcast
This commit is contained in:
parent
04e5e3cd29
commit
a9131058ab
3 changed files with 48 additions and 6 deletions
|
@ -196,7 +196,16 @@
|
||||||
<Row>
|
<Row>
|
||||||
<i-col span="12" style="padding-right:10px">
|
<i-col span="12" style="padding-right:10px">
|
||||||
<Select v-model="model11" filterable>
|
<Select v-model="model11" filterable>
|
||||||
<i-option v-for="item in cityList" :value="item.value">{{ item.label }}</i-option>
|
<Option-group label="123">
|
||||||
|
<i-option value="beijing">北京市</i-option>
|
||||||
|
<i-option value="shanghai">上海市</i-option>
|
||||||
|
</Option-group>
|
||||||
|
<Option-group label="456">
|
||||||
|
<i-option value="shenzhen">深圳市</i-option>
|
||||||
|
<i-option value="hangzhou">杭州市</i-option>
|
||||||
|
</Option-group>
|
||||||
|
<i-option value="nanjing">南京市</i-option>
|
||||||
|
<i-option value="chongqing">重庆市</i-option>
|
||||||
</Select>
|
</Select>
|
||||||
</i-col>
|
</i-col>
|
||||||
<i-col span="12">
|
<i-col span="12">
|
||||||
|
|
|
@ -36,7 +36,7 @@
|
||||||
import Icon from '../icon';
|
import Icon from '../icon';
|
||||||
import Drop from './dropdown.vue';
|
import Drop from './dropdown.vue';
|
||||||
import clickoutside from '../../directives/clickoutside';
|
import clickoutside from '../../directives/clickoutside';
|
||||||
import { oneOf, MutationObserver } from '../../utils/assist';
|
import { oneOf, MutationObserver, findComponentDownward } from '../../utils/assist';
|
||||||
import { t } from '../../locale';
|
import { t } from '../../locale';
|
||||||
import Emitter from '../../mixins/emitter';
|
import Emitter from '../../mixins/emitter';
|
||||||
|
|
||||||
|
@ -507,6 +507,7 @@
|
||||||
document.addEventListener('keydown', this.handleKeydown);
|
document.addEventListener('keydown', this.handleKeydown);
|
||||||
|
|
||||||
// watch slot changed
|
// watch slot changed
|
||||||
|
// todo 在 child 的 mounted 和 beforeDestroy 里处理
|
||||||
if (MutationObserver) {
|
if (MutationObserver) {
|
||||||
this.observer = new MutationObserver(() => {
|
this.observer = new MutationObserver(() => {
|
||||||
this.modelToQuery();
|
this.modelToQuery();
|
||||||
|
@ -590,9 +591,12 @@
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
query (val) {
|
query (val) {
|
||||||
// todo 这里会重复
|
if (findComponentDownward(this, 'OptionGroup')) {
|
||||||
this.broadcast('OptionGroup', 'on-query-change', val);
|
this.broadcast('OptionGroup', 'on-query-change', val);
|
||||||
this.broadcast('iOption', 'on-query-change', val);
|
this.broadcast('iOption', 'on-query-change', val);
|
||||||
|
} else {
|
||||||
|
this.broadcast('iOption', 'on-query-change', val);
|
||||||
|
}
|
||||||
let is_hidden = true;
|
let is_hidden = true;
|
||||||
|
|
||||||
this.$nextTick(() => {
|
this.$nextTick(() => {
|
||||||
|
|
|
@ -184,3 +184,32 @@ function findComponentUpward (content, componentName, componentNames) {
|
||||||
return parent;
|
return parent;
|
||||||
}
|
}
|
||||||
export {findComponentUpward};
|
export {findComponentUpward};
|
||||||
|
|
||||||
|
// Find components downward
|
||||||
|
function findComponentDownward (content, componentName) {
|
||||||
|
let childrens = content.$children;
|
||||||
|
let children = null;
|
||||||
|
|
||||||
|
if (childrens.length) {
|
||||||
|
childrens.forEach(child => {
|
||||||
|
const name = child.$options.name;
|
||||||
|
if (name === componentName) {
|
||||||
|
children = child;
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
for (let i = 0; i < childrens.length; i++) {
|
||||||
|
const child = childrens[i];
|
||||||
|
const name = child.$options.name;
|
||||||
|
if (name === componentName) {
|
||||||
|
children = child;
|
||||||
|
break;
|
||||||
|
} else {
|
||||||
|
children = findComponentDownward(child, componentName);
|
||||||
|
if (children) break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return children;
|
||||||
|
}
|
||||||
|
export {findComponentDownward};
|
Loading…
Add table
Reference in a new issue