nebv
2020-10-13 bbfb06f0ad1e345b0e716da730acaf7c0a778e4b
perf: optimize preview and ContextMenu functions
2个文件已修改
28 ■■■■ 已修改文件
src/components/ContextMenu/index.ts 15 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/Preview/src/functional.ts 13 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/ContextMenu/index.ts
@@ -1,7 +1,7 @@
import contextMenuVue from './src/index';
import { isClient } from '/@/utils/is';
import { Options, Props } from './src/types';
import { createApp } from 'vue';
import { createVNode, render } from 'vue';
const menuManager: {
  doms: Element[];
  resolve: Fn;
@@ -19,7 +19,7 @@
  if (!isClient) return;
  return new Promise((resolve) => {
    const wrapDom = document.createElement('div');
    const container = document.createElement('div');
    const propsData: Partial<Props> = {};
    if (options.styles !== undefined) propsData.styles = options.styles;
    if (options.items !== undefined) propsData.items = options.items;
@@ -27,12 +27,12 @@
      propsData.customEvent = event;
      propsData.axis = { x: event.clientX, y: event.clientY };
    }
    createApp(contextMenuVue, propsData).mount(wrapDom);
    const vm = createVNode(contextMenuVue, propsData);
    render(vm, container);
    const bodyClick = function () {
      menuManager.resolve('');
    };
    const contextMenuDom = wrapDom.children[0];
    menuManager.doms.push(contextMenuDom);
    menuManager.doms.push(container);
    const remove = function () {
      menuManager.doms.forEach((dom: Element) => {
        try {
@@ -41,16 +41,13 @@
      });
      document.body.removeEventListener('click', bodyClick);
      document.body.removeEventListener('scroll', bodyClick);
      try {
        (wrapDom as any) = null;
      } catch (error) {}
    };
    menuManager.resolve = function (...arg: any) {
      resolve(arg[0]);
      remove();
    };
    remove();
    document.body.appendChild(contextMenuDom);
    document.body.appendChild(container);
    document.body.addEventListener('click', bodyClick);
    document.body.addEventListener('scroll', bodyClick);
  });
src/components/Preview/src/functional.ts
@@ -3,19 +3,20 @@
import type { Options, Props } from './types';
import { createApp } from 'vue';
import { createVNode, render } from 'vue';
let instance: any = null;
export function createImgPreview(options: Options) {
  if (!isClient) return;
  const { imageList, show = true, index = 0 } = options;
  const propsData: Partial<Props> = {};
  const wrapDom = document.createElement('div');
  const container = document.createElement('div');
  propsData.imageList = imageList;
  propsData.show = show;
  propsData.index = index;
  const imgDom = createApp(ImgPreview, propsData);
  imgDom.mount(wrapDom);
  const imgPreviewDom = wrapDom.children[0];
  document.body.appendChild(imgPreviewDom);
  instance = createVNode(ImgPreview, propsData);
  render(instance, container);
  document.body.appendChild(container);
}