perf(Overlay): lazy render

This commit is contained in:
chenjiahan 2020-09-14 20:46:13 +08:00
parent d783fcf2f4
commit 46e158fa01

View File

@ -1,6 +1,7 @@
import { Transition } from 'vue'; import { Transition } from 'vue';
import { createNamespace, isDef, noop } from '../utils'; import { createNamespace, isDef, noop } from '../utils';
import { preventDefault } from '../utils/dom/event'; import { preventDefault } from '../utils/dom/event';
import { useLazyRender } from '../composition/use-lazy-render';
const [createComponent, bem] = createNamespace('overlay'); const [createComponent, bem] = createNamespace('overlay');
@ -22,7 +23,9 @@ export default createComponent({
}, },
setup(props, { slots }) { setup(props, { slots }) {
return function () { const lazyRender = useLazyRender(() => props.show);
const renderOverlay = lazyRender(() => {
const style = { const style = {
zIndex: props.zIndex, zIndex: props.zIndex,
...props.customStyle, ...props.customStyle,
@ -33,7 +36,6 @@ export default createComponent({
} }
return ( return (
<Transition name="van-fade">
<div <div
vShow={props.show} vShow={props.show}
style={style} style={style}
@ -42,8 +44,9 @@ export default createComponent({
> >
{slots.default?.()} {slots.default?.()}
</div> </div>
</Transition>
); );
}; });
return () => <Transition name="van-fade">{renderOverlay()}</Transition>;
}, },
}); });