perf: optimize select animate

pull/3128/head
tanjinzhou 2020-11-05 18:09:02 +08:00
parent 8ba8983353
commit 7125d84fa2
2 changed files with 10 additions and 19 deletions

@ -1 +1 @@
Subproject commit bef135d01e96fadf80f7a09c7cd26b18aa6d71d8 Subproject commit 7f7141a1dd62488287157dee6a1af52716924c62

View File

@ -135,32 +135,23 @@ const OptionList = defineComponent<OptionListProps, { state?: any }>({
); );
// Auto scroll to item position in single mode // Auto scroll to item position in single mode
let timeoutId: number;
watch( watch(
computed(() => props.open), computed(() => props.open),
() => { () => {
/**
* React will skip `onChange` when component update.
* `setActive` function will call root accessibility state update which makes re-render.
* So we need to delay to let Input component trigger onChange first.
*/
clearTimeout(timeoutId);
timeoutId = setTimeout(() => {
if (!props.multiple && props.open && props.values.size === 1) { if (!props.multiple && props.open && props.values.size === 1) {
const value = Array.from(props.values)[0]; const value = Array.from(props.values)[0];
const index = props.flattenOptions.findIndex(({ data }) => data.value === value); const index = props.flattenOptions.findIndex(({ data }) => data.value === value);
setActive(index); // setActive(index);
scrollIntoView(index); scrollIntoView(index);
} }
});
// Force trigger scrollbar visible when open // Force trigger scrollbar visible when open
if (props.open) { if (props.open) {
nextTick(() => { nextTick(() => {
listRef.current?.scrollTo(undefined); listRef.current?.scrollTo(undefined);
}) });
} }
}, },
{ immediate: true }, { immediate: true, flush: 'post' },
); );
// ========================== Values ========================== // ========================== Values ==========================