UNPKG

ant-design-vue

Version:

An enterprise-class UI design language and Vue-based implementation

57 lines (56 loc) 2.51 kB
"use strict"; var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault"); Object.defineProperty(exports, "__esModule", { value: true }); exports.cloneElement = cloneElement; exports.cloneVNodes = cloneVNodes; exports.deepCloneElement = deepCloneElement; exports.triggerVNodeUpdate = triggerVNodeUpdate; var _extends2 = _interopRequireDefault(require("@babel/runtime/helpers/extends")); var _propsUtil = require("./props-util"); var _vue = require("vue"); var _warning = _interopRequireDefault(require("./warning")); function cloneElement(vnode) { let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; let mergeRef = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; let ele = vnode; if (Array.isArray(vnode)) { ele = (0, _propsUtil.filterEmpty)(vnode)[0]; } if (!ele) { return null; } const node = (0, _vue.cloneVNode)(ele, nodeProps, mergeRef); // cloneVNode内部是合并属性,这里改成覆盖属性 node.props = override ? (0, _extends2.default)((0, _extends2.default)({}, node.props), nodeProps) : node.props; (0, _warning.default)(typeof node.props.class !== 'object', 'class must be string'); return node; } function cloneVNodes(vnodes) { let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; return vnodes.map(vnode => cloneElement(vnode, nodeProps, override)); } function deepCloneElement(vnode) { let nodeProps = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : {}; let override = arguments.length > 2 && arguments[2] !== undefined ? arguments[2] : true; let mergeRef = arguments.length > 3 && arguments[3] !== undefined ? arguments[3] : false; if (Array.isArray(vnode)) { return vnode.map(item => deepCloneElement(item, nodeProps, override, mergeRef)); } else { // 需要判断是否为vnode方可进行clone操作 if (!(0, _vue.isVNode)(vnode)) { return vnode; } const cloned = cloneElement(vnode, nodeProps, override, mergeRef); if (Array.isArray(cloned.children)) { cloned.children = deepCloneElement(cloned.children); } return cloned; } } function triggerVNodeUpdate(vm, attrs, dom) { (0, _vue.render)((0, _vue.cloneVNode)(vm, (0, _extends2.default)({}, attrs)), dom); }