UNPKG

vxe-table-demonic

Version:

一个基于 vue 的 PC 端表单/表格组件,支持增删改查、虚拟列表、虚拟树、懒加载、快捷菜单、数据校验、树形结构、打印导出、表单渲染、数据分页、弹窗、自定义模板、渲染器、JSON 配置式...

94 lines (93 loc) 2.93 kB
"use strict"; Object.defineProperty(exports, "__esModule", { value: true }); exports.XEResizeObserver = void 0; exports.createResizeEvent = createResizeEvent; var _xeUtils = _interopRequireDefault(require("xe-utils")); var _conf = _interopRequireDefault(require("../v-x-e-table/src/conf")); function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; } /** * 监听 resize 事件 * 如果项目中已使用了 resize-observer-polyfill,那么只需要将方法定义全局,该组件就会自动使用 */ var resizeTimeout; /* eslint-disable no-use-before-define */ var eventStore = []; var defaultInterval = 500; function eventHandle() { if (eventStore.length) { eventStore.forEach(function (item) { item.tarList.forEach(function (observer) { var target = observer.target, width = observer.width, heighe = observer.heighe; var clientWidth = target.clientWidth; var clientHeight = target.clientHeight; var rWidth = clientWidth && width !== clientWidth; var rHeight = clientHeight && heighe !== clientHeight; if (rWidth || rHeight) { observer.width = clientWidth; observer.heighe = clientHeight; setTimeout(item.callback); } }); }); /* eslint-disable @typescript-eslint/no-use-before-define */ eventListener(); } } function eventListener() { clearTimeout(resizeTimeout); resizeTimeout = setTimeout(eventHandle, _conf.default.resizeInterval || defaultInterval); } var XEResizeObserver = /** @class */function () { function XEResizeObserver(callback) { this.tarList = []; this.callback = callback; } XEResizeObserver.prototype.observe = function (target) { var _this = this; if (target) { var tarList = this.tarList; if (!tarList.some(function (observer) { return observer.target === target; })) { tarList.push({ target: target, width: target.clientWidth, heighe: target.clientHeight }); } if (!eventStore.length) { eventListener(); } if (!eventStore.some(function (item) { return item === _this; })) { eventStore.push(this); } } }; XEResizeObserver.prototype.unobserve = function (target) { _xeUtils.default.remove(eventStore, function (item) { return item.tarList.some(function (observer) { return observer.target === target; }); }); }; XEResizeObserver.prototype.disconnect = function () { var _this = this; _xeUtils.default.remove(eventStore, function (item) { return item === _this; }); }; return XEResizeObserver; }(); exports.XEResizeObserver = XEResizeObserver; function createResizeEvent(callback) { if (window.ResizeObserver) { return new window.ResizeObserver(callback); } return new XEResizeObserver(callback); }