Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
DiDi
cube-ui
提交
c8c1056e
C
cube-ui
项目概览
DiDi
/
cube-ui
大约 1 年 前同步成功
通知
34
Star
9078
Fork
1508
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
C
cube-ui
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
c8c1056e
编写于
4月 24, 2018
作者:
D
dolymood
浏览文件
操作
浏览文件
下载
差异文件
Merge branch 'dev' of github.com:didi/cube-ui into dev
上级
d715859a
4913948e
变更
5
隐藏空白更改
内联
并排
Showing
5 changed file
with
46 addition
and
8 deletion
+46
-8
src/common/helpers/create-api-component.js
src/common/helpers/create-api-component.js
+27
-7
src/common/helpers/dom.js
src/common/helpers/dom.js
+1
-0
src/common/helpers/instantiate-component.js
src/common/helpers/instantiate-component.js
+7
-1
src/common/helpers/raf.js
src/common/helpers/raf.js
+8
-0
src/common/helpers/util.js
src/common/helpers/util.js
+3
-0
未找到文件。
src/common/helpers/create-api-component.js
浏览文件 @
c8c1056e
...
...
@@ -9,11 +9,17 @@ export default function createAPIComponent(Vue, Component, events = [], single =
before
(
fn
)
{
beforeFns
.
push
(
fn
)
},
open
(
data
,
renderFn
,
instanceSingle
)
{
if
(
typeof
renderFn
!==
'
function
'
)
{
instanceSingle
=
renderFn
open
(
data
,
renderFn
,
options
)
{
if
(
typeof
renderFn
!==
'
function
'
&&
options
===
undefined
)
{
options
=
renderFn
renderFn
=
null
}
let
instanceSingle
=
options
if
(
typeof
options
===
'
object
'
)
{
instanceSingle
=
!!
options
.
single
delete
options
.
single
}
beforeFns
.
forEach
((
before
)
=>
{
before
(
data
,
renderFn
,
instanceSingle
)
})
...
...
@@ -26,7 +32,7 @@ export default function createAPIComponent(Vue, Component, events = [], single =
// singleComponent.show && singleComponent.show()
return
singleComponent
}
const
component
=
instantiateComponent
(
Vue
,
Component
,
data
,
renderFn
)
const
component
=
instantiateComponent
(
Vue
,
Component
,
data
,
renderFn
,
options
)
const
instance
=
component
.
$parent
const
originRemove
=
component
.
remove
...
...
@@ -61,13 +67,27 @@ export default function createAPIComponent(Vue, Component, events = [], single =
},
create
(
config
,
renderFn
,
single
)
{
const
ownerInstance
=
this
const
isInVueInstance
=
!!
ownerInstance
.
$on
const
renderData
=
parseRenderData
(
config
,
events
)
cancelWatchProps
()
processProps
()
processEvents
()
const
component
=
api
.
open
(
renderData
,
renderFn
,
single
)
if
(
typeof
renderFn
!==
'
function
'
&&
single
===
undefined
)
{
single
=
!!
renderFn
renderFn
=
null
}
// to get Vue options
// store router i18n ...
const
options
=
{
single
:
single
}
if
(
isInVueInstance
)
{
options
.
parent
=
ownerInstance
}
const
component
=
api
.
open
(
renderData
,
renderFn
,
options
)
if
(
component
.
__cube__parent
!==
ownerInstance
)
{
component
.
__cube__parent
=
ownerInstance
const
beforeDestroy
=
function
()
{
...
...
@@ -78,7 +98,7 @@ export default function createAPIComponent(Vue, Component, events = [], single =
ownerInstance
.
$off
(
'
hook:beforeDestroy
'
,
beforeDestroy
)
component
.
__cube__parent
=
null
}
ownerInstance
.
$on
&&
ownerInstance
.
$on
(
'
hook:beforeDestroy
'
,
beforeDestroy
)
isInVueInstance
&&
ownerInstance
.
$on
(
'
hook:beforeDestroy
'
,
beforeDestroy
)
}
return
component
...
...
@@ -100,7 +120,7 @@ export default function createAPIComponent(Vue, Component, events = [], single =
renderData
.
props
[
key
]
=
propKey
}
})
if
(
ownerInstance
.
$watch
)
{
if
(
isInVueInstance
)
{
ownerInstance
.
__createAPI_watcher
=
ownerInstance
.
$watch
(
function
()
{
const
props
=
{}
watchKeys
.
forEach
((
key
,
i
)
=>
{
...
...
src/common/helpers/dom.js
浏览文件 @
c8c1056e
...
...
@@ -65,6 +65,7 @@ let vendor = (() => {
})()
export
function
prefixStyle
(
style
)
{
/* istanbul ignore if */
if
(
vendor
===
false
)
{
return
false
}
...
...
src/common/helpers/instantiate-component.js
浏览文件 @
c8c1056e
export
default
function
instantiateComponent
(
Vue
,
Component
,
data
,
renderFn
)
{
export
default
function
instantiateComponent
(
Vue
,
Component
,
data
,
renderFn
,
options
)
{
let
renderData
let
childrenRenderFn
if
(
options
===
undefined
)
{
options
=
{}
}
const
instance
=
new
Vue
({
...
options
,
render
(
createElement
)
{
let
children
=
childrenRenderFn
&&
childrenRenderFn
(
createElement
)
if
(
children
&&
!
Array
.
isArray
(
children
))
{
...
...
src/common/helpers/raf.js
浏览文件 @
c8c1056e
...
...
@@ -11,10 +11,14 @@ export const requestAnimationFrame = (() => {
return
noop
}
return
window
.
requestAnimationFrame
||
/* istanbul ignore next */
window
.
webkitRequestAnimationFrame
||
/* istanbul ignore next */
window
.
mozRequestAnimationFrame
||
/* istanbul ignore next */
window
.
oRequestAnimationFrame
||
// if all else fails, use setTimeout
/* istanbul ignore next */
function
(
callback
)
{
return
window
.
setTimeout
(
callback
,
(
callback
.
interval
||
DEFAULT_INTERVAL
)
/
2
)
// make interval as precise as possible.
}
...
...
@@ -26,9 +30,13 @@ export const cancelAnimationFrame = (() => {
return
noop
}
return
window
.
cancelAnimationFrame
||
/* istanbul ignore next */
window
.
webkitCancelAnimationFrame
||
/* istanbul ignore next */
window
.
mozCancelAnimationFrame
||
/* istanbul ignore next */
window
.
oCancelAnimationFrame
||
/* istanbul ignore next */
function
(
id
)
{
window
.
clearTimeout
(
id
)
}
...
...
src/common/helpers/util.js
浏览文件 @
c8c1056e
...
...
@@ -2,7 +2,9 @@ function findIndex(ary, fn) {
if
(
ary
.
findIndex
)
{
return
ary
.
findIndex
(
fn
)
}
/* istanbul ignore next */
let
index
=
-
1
/* istanbul ignore next */
ary
.
some
(
function
(
item
,
i
,
ary
)
{
const
ret
=
fn
.
call
(
this
,
item
,
i
,
ary
)
if
(
ret
)
{
...
...
@@ -10,6 +12,7 @@ function findIndex(ary, fn) {
return
ret
}
})
/* istanbul ignore next */
return
index
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录