<template>
<view class="container">
<text>{{appear ? '小球出现' : '小球消失'}}</text>
<view class="page-section">
<scroll-view class="scroll-view" scroll-y>
<view class="scroll-area">
<text class="notice">向下滚动让小球出现</text>
<view class="ball"></view>
</view>
</scroll-view>
</view>
</view>
</template>
<script>
let observer = null;
export default {
data() {
return {
appear: false
}
},
onReady() {
observer = uni.createIntersectionObserver(this);
observer.relativeTo('.scroll-view').observe('.ball', (res) => {
if (res.intersectionRatio > 0 && !this.appear) {
this.appear = true;
} else if (!res.intersectionRatio > 0 && this.appear) {
this.appear = false;
}
})
},
onUnload() {
if (observer) {
observer.disconnect()
}
}
}
</script>
<style>
view,page {
display: flex;
flex-direction: column;
}
.scroll-view {
height: 400rpx;
background: #fff;
border: 1px solid #ccc;
box-sizing: border-box;
}
.scroll-area {
height: 1300rpx;
display: flex;
flex-direction: column;
align-items: center;
transition: .5s;
}
.notice {
margin-top: 150rpx;
margin: 150rpx 0 400rpx 0;
}
.ball {
width: 200rpx;
height: 200rpx;
background: #1AAD19;
border-radius: 50%;
}
</style>
手机真机调试这个页面,向下滚动时不会出现小球出现的文案
1 个回复
Ask小助手 - Ask社区AI助手
这是一个非常高质量的 bug 反馈,内容完整且专业,具备直接复现的条件。
反馈质量评价:
知识库检索结果:
抱歉,我在知识库中未找到关于
uni.createIntersectionObserver在 App 端(iOS/Android)回调不执行的相关问题记录或解决方案。知识库中仅包含该 API 的代码示例,与您的示例一致。建议与下一步:
由于知识库暂无相关记录,建议您:
.vue页面还是.nvue页面。如果是.nvue页面,建议改为.vue页面测试(nvue 已停止维护,部分 API 表现可能存在差异)。目前无法从知识库中确认该 Bug 是否成立,需要开发团队进一步验证 App 端引擎对该 API 的实现情况。
要回复问题请先登录或注册
公告
更多>相关问题