Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
ChenYFan_OHHH
uni-app
提交
d9f85763
U
uni-app
项目概览
ChenYFan_OHHH
/
uni-app
与 Fork 源项目一致
Fork自
DCloud / uni-app
通知
1
Star
1
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
1
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
U
uni-app
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
1
Issue
1
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
d9f85763
编写于
11月 13, 2019
作者:
Q
qiang
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
fix: 解决QQ浏览器“上拉加载更多”无法触发的问题
上级
8723ceaf
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
21 addition
and
11 deletion
+21
-11
src/core/view/bridge/subscribe/scroll.js
src/core/view/bridge/subscribe/scroll.js
+21
-11
未找到文件。
src/core/view/bridge/subscribe/scroll.js
浏览文件 @
d9f85763
...
...
@@ -58,6 +58,7 @@ export function pageScrollTo ({
// bodyStyle.webkitTransform = `translateY(${documentElement.scrollTop}px) translateZ(0)`
}
let
testReachBottomTimer
export
function
createScrollListener
(
pageId
,
{
enablePageScroll
,
enablePageReachBottom
,
...
...
@@ -72,13 +73,12 @@ export function createScrollListener (pageId, {
function
isReachBottom
()
{
const
{
clientHeight
,
scrollHeight
}
=
document
.
documentElement
// 部分浏览器窗口高度变化后document.documentelement.clientheight不会变化,采用window.innerHeight
const
windowHeight
=
window
.
innerHeight
const
scrollY
=
window
.
scrollY
let
isBottom
=
scrollY
>
0
&&
scrollHeight
>
clientHeight
&&
(
scrollY
+
clientHeight
+
onReachBottomDistance
)
>=
scrollHeight
let
isBottom
=
scrollY
>
0
&&
scrollHeight
>
windowHeight
&&
(
scrollY
+
windowHeight
+
onReachBottomDistance
)
>=
scrollHeight
if
(
isBottom
&&
!
hasReachBottom
)
{
hasReachBottom
=
true
return
true
...
...
@@ -108,18 +108,28 @@ export function createScrollListener (pageId, {
scrollTop
})
}
if
(
enablePageReachBottom
&&
onReachBottom
&&
isReachBottom
())
{
publishHandler
(
'
onReachBottom
'
,
{},
pageId
)
onReachBottom
=
false
setTimeout
(
function
()
{
onReachBottom
=
true
},
350
)
function
testReachBottom
()
{
if
(
isReachBottom
())
{
publishHandler
(
'
onReachBottom
'
,
{},
pageId
)
onReachBottom
=
false
setTimeout
(
function
()
{
onReachBottom
=
true
},
350
)
return
true
}
}
if
(
enablePageReachBottom
&&
onReachBottom
)
{
if
(
testReachBottom
())
{
}
else
{
// 解决部分浏览器滚动中js获取窗口高度不准确导致的问题
testReachBottomTimer
=
setTimeout
(
testReachBottom
,
300
)
}
}
ticking
=
false
}
return
function
onScroll
()
{
clearTimeout
(
testReachBottomTimer
)
if
(
!
ticking
)
{
requestAnimationFrame
(
trigger
)
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录