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 @@