Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
leizi929
Sortable
提交
f3b245ea
S
Sortable
项目概览
leizi929
/
Sortable
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
Sortable
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
前往新版Gitcode,体验更适合开发者的 AI 搜索 >>
提交
f3b245ea
编写于
11月 23, 2018
作者:
F
FIRST_NAME LAST_NAME
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
added `bubbleScroll` option; added proper ability to cancel _throttle
上级
cd01d01f
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
27 addition
and
18 deletion
+27
-18
Sortable.js
Sortable.js
+27
-18
未找到文件。
Sortable.js
浏览文件 @
f3b245ea
...
...
@@ -212,7 +212,7 @@
}
}
layersOut
++
;
}
while
(
currentParent
=
_getParentAutoScrollElement
(
currentParent
,
false
));
}
while
(
options
.
bubbleScroll
&&
(
currentParent
=
_getParentAutoScrollElement
(
currentParent
,
false
)
));
}
},
30
),
...
...
@@ -306,6 +306,7 @@
scroll
:
true
,
scrollSensitivity
:
30
,
scrollSpeed
:
10
,
bubbleScroll
:
true
,
draggable
:
/
[
uo
]
l/i
.
test
(
el
.
nodeName
)
?
'
li
'
:
'
>*
'
,
ghostClass
:
'
sortable-ghost
'
,
chosenClass
:
'
sortable-chosen
'
,
...
...
@@ -446,19 +447,19 @@
_handleAutoScroll
:
function
(
evt
)
{
if
(
!
dragEl
||
!
this
.
options
.
scroll
||
(
this
.
options
.
supportPointer
&&
evt
.
type
==
'
touchmove
'
))
return
;
var
x
=
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
).
clientX
,
y
=
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
).
clientY
,
x
=
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
).
clientX
,
y
=
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
).
clientY
,
elem
=
document
.
elementFromPoint
(
x
,
y
),
_this
=
this
;
elem
=
document
.
elementFromPoint
(
x
,
y
),
_this
=
this
;
// touch does not have native autoscroll, even with DnD enabled
if
(
!
this
.
nativeDraggable
||
evt
.
touches
||
(
evt
.
pointerType
&&
evt
.
pointerType
==
'
touch
'
))
{
if
(
!
_
this
.
nativeDraggable
||
evt
.
touches
||
(
evt
.
pointerType
&&
evt
.
pointerType
==
'
touch
'
))
{
_autoScroll
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
,
this
.
options
,
elem
);
_autoScroll
(
evt
.
touches
?
evt
.
touches
[
0
]
:
evt
,
_
this
.
options
,
elem
);
// Listener for pointer element change
var
ogElemScroller
=
_getParentAutoScrollElement
(
elem
,
true
);
...
...
@@ -467,8 +468,9 @@
y
!=
lastPointerElemY
)
{
pointerElemChangedInterval
&&
clearInterval
(
pointerElemChangedInterval
);
// Detect for pointer elem change, emulating native DnD behaviour
pointerElemChangedInterval
=
setInterval
(
function
()
{
if
(
!
dragEl
)
return
;
var
newElem
=
_getParentAutoScrollElement
(
document
.
elementFromPoint
(
x
,
y
),
true
);
if
(
newElem
!=
ogElemScroller
)
{
ogElemScroller
=
newElem
;
...
...
@@ -482,7 +484,8 @@
}
else
{
// if DnD is enabled, first autoscroll will already scroll, so get parent autoscroll of first autoscroll
_autoScroll
(
evt
,
this
.
options
,
_getParentAutoScrollElement
(
elem
,
false
));
if
(
!
options
.
bubbleScroll
)
return
;
_autoScroll
(
evt
,
_this
.
options
,
_getParentAutoScrollElement
(
elem
,
false
));
}
},
...
...
@@ -1019,8 +1022,9 @@
clearInterval
(
this
.
_loopId
);
clearInterval
(
pointerElemChangedInterval
);
_clearAutoScrolls
();
clearInterval
(
pointerElemChangedInterval
);
;
_cancelThrottle
()
;
clearTimeout
(
this
.
_dragStartTimer
);
...
...
@@ -1546,27 +1550,32 @@
return
false
;
}
var
_throttleTimeout
;
function
_throttle
(
callback
,
ms
)
{
var
args
,
_this
;
return
function
()
{
if
(
args
===
void
0
)
{
args
=
arguments
;
_this
=
this
;
if
(
!
_throttleTimeout
)
{
var
args
=
arguments
,
_this
=
this
;
setTimeout
(
function
()
{
_throttleTimeout
=
setTimeout
(
function
()
{
if
(
args
.
length
===
1
)
{
callback
.
call
(
_this
,
args
[
0
]);
}
else
{
callback
.
apply
(
_this
,
args
);
}
args
=
void
0
;
_throttleTimeout
=
void
0
;
},
ms
);
}
};
}
function
_cancelThrottle
()
{
clearTimeout
(
_throttleTimeout
);
_throttleTimeout
=
void
0
;
}
function
_extend
(
dst
,
src
)
{
if
(
dst
&&
src
)
{
for
(
var
key
in
src
)
{
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录