From 8341fe44fc1bc50e5c0f9a67290a1b591d10b34a Mon Sep 17 00:00:00 2001 From: tangjinzhou <415800467@qq.com> Date: Mon, 8 Jan 2018 18:31:04 +0800 Subject: [PATCH] fix --- components/_util/Clone.vue | 19 +++ components/_util/vnode.js | 43 ++++- components/menu/demo/antd.vue | 158 ++++++++++--------- components/menu/src/Menu.vue | 16 +- components/menu/src/MenuItem.vue | 10 +- components/menu/src/MenuMixin.js | 5 + components/menu/src/SubMenu.vue | 64 +++++--- components/menu/src/commonPropsType.js | 11 +- components/menu/style/index.js | 2 + components/menu/{assets => style}/index.less | 17 +- components/style.js | 2 + components/trigger/Popup.vue | 27 +++- components/trigger/index.vue | 4 +- webpack.config.js | 2 +- 14 files changed, 251 insertions(+), 129 deletions(-) create mode 100644 components/_util/Clone.vue create mode 100644 components/menu/style/index.js rename components/menu/{assets => style}/index.less (95%) diff --git a/components/_util/Clone.vue b/components/_util/Clone.vue new file mode 100644 index 000000000..96ba840df --- /dev/null +++ b/components/_util/Clone.vue @@ -0,0 +1,19 @@ + diff --git a/components/_util/vnode.js b/components/_util/vnode.js index de21cefba..e3225d29a 100644 --- a/components/_util/vnode.js +++ b/components/_util/vnode.js @@ -1,5 +1,31 @@ import clonedeep from 'lodash.clonedeep' +// export function cloneVNode (vnode, deep) { +// const cloned = new vnode.constructor( +// vnode.tag, +// clonedeep(vnode.data), +// vnode.children, +// vnode.text, +// vnode.elm, +// vnode.context, +// clonedeep(vnode.componentOptions), +// vnode.asyncFactory +// ) +// cloned.ns = vnode.ns +// cloned.isStatic = vnode.isStatic +// cloned.key = vnode.key +// cloned.isComment = vnode.isComment +// cloned.isCloned = true +// if (deep && vnode.children) { +// cloned.children = cloneVNodes(vnode.children, deep) +// } +// return cloned +// } export function cloneVNode (vnode, deep) { + const componentOptions = vnode.componentOptions + // if (componentOptions) { + // componentOptions.propsData = componentOptions.propsData ? clonedeep(componentOptions.propsData) : componentOptions.propsData + // } + const cloned = new vnode.constructor( vnode.tag, clonedeep(vnode.data), @@ -7,16 +33,24 @@ export function cloneVNode (vnode, deep) { vnode.text, vnode.elm, vnode.context, - clonedeep(vnode.componentOptions), + componentOptions, vnode.asyncFactory ) cloned.ns = vnode.ns cloned.isStatic = vnode.isStatic cloned.key = vnode.key cloned.isComment = vnode.isComment + cloned.fnContext = vnode.fnContext + cloned.fnOptions = vnode.fnOptions + cloned.fnScopeId = vnode.fnScopeId cloned.isCloned = true - if (deep && vnode.children) { - cloned.children = cloneVNodes(vnode.children) + if (deep) { + if (vnode.children) { + cloned.children = cloneVNodes(vnode.children, true) + } + if (componentOptions && componentOptions.children) { + componentOptions.children = cloneVNodes(componentOptions.children, true) + } } return cloned } @@ -30,7 +64,8 @@ export function cloneVNodes (vnodes, deep) { return res } -export function cloneElement (node, nodeProps) { +export function cloneElement (n, nodeProps, clone) { + const node = clone ? cloneVNode(n, true) : n const { props = {}, key, on = {}} = nodeProps if (node.componentOptions) { node.componentOptions.propsData = node.componentOptions.propsData || {} diff --git a/components/menu/demo/antd.vue b/components/menu/demo/antd.vue index 6713959c2..962af1f3e 100644 --- a/components/menu/demo/antd.vue +++ b/components/menu/demo/antd.vue @@ -1,8 +1,8 @@