1***@qq.com
1***@qq.com
  • 发布:2025-03-31 17:19
  • 更新:2025-03-31 17:19
  • 阅读:22

【报Bug】scroll-view 惯性滚动@scrolltoupper事件不触发,@scroll 事件 e.detail.scrollTop 值不准确

分类:uni-app

产品分类: uniapp/小程序/微信

PC开发环境操作系统: Windows

PC开发环境操作系统版本号: 64位

HBuilderX类型: 正式

HBuilderX版本号: 4.45

第三方开发者工具版本号: Nightly 1.06.2503262

基础库版本号: 3.7.12

项目创建方式: HBuilderX

示例代码:
<template> <scroll-view class="container-wrapper" scroll-y="outerScroll" lower-threshold="0" @scroll="outerScrollHandler"
@scrolltolower="outerToLowerHandler"
>
<view class="detail-imgs">
<view class="no-img" v-if="nearShop.imgs == null || nearShop.imgs.length === 0">
<image src="/static/images/noimg.png"/>
</view>
<swiper v-else circular :indicator-dots="true" :autoplay="true" :interval="5000" :duration="500">
<swiper-item v-for="(content,index) in nearShop.imgs" :key="index">
<image :src="content.url" @click="previewImage(index)"/>
</swiper-item>
</swiper>
</view>
<view class="content">
<!-- 商户信息 -->
<view class="merchant-info">
<view class="name">{{ nearShop.name }}</view>
<view class="open-time">开放时间:{{ nearShop.businessHoursStart + '-' + nearShop.businessHoursEnd }}</view>
</view>
<!-- 地址信息 -->
<view class="address-info">
<view class="address">
<view class="journey">距离我的位置有25.7公里</view>
<view class="specific-address tui-ellipsis">{{ nearShop.address }}</view>
</view>
<view class="map">
<image src="/pagesNls/static/imgs/marker.png" />
<text>地图</text>
</view>
<image src="/pagesNls/static/imgs/phone-icon.png" />
</view>
</view>
<!-- 房间信息 -->
<view class="room-info">
<tui-tabs tabs="tabs" currentTab="currentTab" zIndex="1" sliderHeight="48"
sliderWidth="156"
sliderBgColor="#3A8BE6"
sliderRadius="48rpx"
bottom="8"
selectedColor="#fff"
color="#333"
@change="changeHandler"
></tui-tabs>
<!-- 互动区域 -->
<swiper
class="content-swiper" current="currentTab" duration="300" @change="swiperChangeHandler"
>
<!-- 选房 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
<RoomItem v-for="item in 10" :key="item" />
</view>
</scroll-view>
</swiper-item>
<!-- 服务 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
111
</view>
</scroll-view>
</swiper-item>
<!-- 简介 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
<rich-text :nodes="formatRichText(nearShop.remark)"></rich-text>
</view>
</scroll-view>
</swiper-item>
<!-- 评价 -->
<swiper-item class="swiper-item">
<scroll-view scroll-y="innerScroll" upper-threshold="0" @scroll="innerScrollHandler"
@scrolltoupper="innerToUpperHandler"
>
<view class="swiper-item-wrapper">
aaa
</view>
</scroll-view>
</swiper-item>
</swiper>
</view>
<!-- 图片预览 -->
<tui-gallery :urls="urls" :current="currentIndex" :show="show" @hide="show = false"></tui-gallery>
</scroll-view>
</template>

<script>
import { recordStatVisit } from '@/common/api.js';
import RoomItem from './components/RoomItem.vue';
import { debounce } from '../../components/common/tui-utils/tui-utils';
export default {
components: {
RoomItem
},
data() {
return {
outerScroll: true,
innerScroll: false,
clientHeight: 0,
outerTimer: null,
innerTimer: null,
nearShop: {
"address":"安徽省黄山市黟县西递镇西递西香园客栈西递古村落",
"businessHoursEnd":"23:59",
"businessHoursStart":"00:00",
"businessStatus":"IN_BUSINESS",
"businessStatusText":"营业中",
"communityIds":null,
"communityInfos":null,
"contactName":"1",
"contactTel":"15095227799",
"createTime":"2025-01-14 17:39:35",
"createUserId":100170,
"createUserInfo":null,
"deleteTime":null,
"discountRule":"",
"discountStatus":null,
"discountStatusText":"未知",
"entryStatus":"ESTABLISHED",
"entryStatusText":"已入驻",
"fmImgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/138c1f01-d8ef-41a7-827c-e027c0c8713b.jpg"
}
],
"gdInfo":{
"id":341023103200,
"level":5,
"name":"西递村委会",
"parent":{
"id":341023103000,
"level":4,
"name":"西递镇",
"parent":{
"id":341023000000,
"level":3,
"name":"黟县",
"parent":{
"id":341000000000,
"level":2,
"name":"黄山市",
"parent":{
"id":340000000000,
"level":1,
"name":"安徽省",
"parent":null,
"parentId":0,
"status":1
},
"parentId":340000000000,
"status":1
},
"parentId":341000000000,
"status":1
},
"parentId":341023000000,
"status":1
},
"parentId":341023103000,
"status":1
},
"governmentDistrictId":341023103200,
"hotline":"18255962666",
"id":100052,
"imgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/5bd6f7a6-fdfe-49fa-b568-33d64f1195e0.jpg"
},
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/d00bc01a-528b-4c5a-b8ea-f82fa9cb43f1.jpg"
},
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/9f8f4f29-f9aa-402b-8d93-9d7dde912440.jpg"
}
],
"latitude":29.901661,
"longitude":117.993477,
"name":"泊心云舍·明经园(黄山黟县西递古村店)",
"notice":"<p><strong>订房必读</strong>:<br/>到达提示:<br/>酒店位于景区内,进入酒店需购买景区门票,请提前联系酒店确认景区营业时间及门票购买事宜。</p><p></p><p><strong>入离时间:</strong><br/><strong>入住时间: 14:00后</strong><br/><strong>退房时间: 12:00前</strong></p><p></p><p><strong>接待提示</strong><br/><strong>年龄限制</strong><br/>入住办理人需年满18岁<br/><strong>可接待人群</strong><br/>接待来自任何国家/地区的客人</p><p><br/><strong>前台服务</strong><br/>前台营业时间:24小时营业</p><p></p><p><strong>宠物</strong><br/>不可携带宠物</p><p>服务型动物<br/>不可携带服务型动物</p><p></p><p><strong>早餐</strong><br/>餐食类型:西式、中式<br/>餐食形式:<br/>自助餐,¥128每份 每天07:30-10:00开放</p><p></p><p><strong>预订提示</strong><br/>订单需等酒店或供应商确认后生效,订单确认结果以平台短信、邮件或app通知为准。</p><p>收费说明<br/>住宿方不收取押金</p><p></p><p><strong>客房使用</strong><br/><strong>商业拍摄</strong><br/>允许商业拍摄<br/><strong>做饭</strong><br/>不允许做饭<br/><strong>派对</strong><br/>允许举办派对/活动</p><p></p><p><strong>支付方式</strong><br/></p><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/111_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/113_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/141_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/14_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/6_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap float-left\" style=\"float:left\"><img class=\"media-wrap image-wrap float-left\" src=\"https://pages.c-ctrip.com/hotels/creditcard/7_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><div class=\"media-wrap image-wrap\"><img class=\"media-wrap image-wrap\" src=\"https://pages.c-ctrip.com/hotels/creditcard/8_pic.png\" width=\"50px\" height=\"30px\" style=\"width:50px;height:30px\"/></div><p></p><p><strong>儿童及加床</strong><br/>欢迎携带儿童入住</p><p><br/><strong>婴儿床及加床政策</strong><br/>所有房型不可加床、不提供婴儿床<br/>年龄床铺费用</p><p>6岁及以下使用现有床铺<span style=\"color:#06875a\">免费</span></p><p>7-14岁使用现有床铺¥ 388/人·晚</p><p>15-17岁使用现有床铺¥ 688/人·晚</p><p></p><p><strong>儿童早餐</strong><br/>年龄费用6岁及以下<span style=\"color:#06875a\">免费</span></p><p>7-14岁¥ 68/人</p><p>15-17岁¥ 128/人</p>",
"ownerPartnerId":100032,
"ownerPartnerInfo":{
"id":100032,
"name":"泊心云舍",
"shortName":"泊心云舍"
},
"partnerId":100004,
"qrCodeImg":"nlsshop/2025/01/38cf88af-a869-46e8-aa79-96384153e27c.png",
"qrCodeImgs":[
{
"name":null,
"url":"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/01/38cf88af-a869-46e8-aa79-96384153e27c.png"
}
],
"recommendationType":"NORMAL",
"recommendationTypeText":"普通",
"remark":"<p></p><div class=\"media-wrap image-wrap\"><img class=\"media-wrap image-wrap\" src=\"http://life-img-1304428295.cos.ap-shanghai.myqcloud.com/nlsshop/2025/03/9b19b425-7ee8-4b30-a959-ec5544719025.jpg\"/></div><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">西递泊心云舍·明经园坐落于黄山脚下西递古村落内牌坊广场、明经湖畔,开门即见近500年历史的胡文光刺史牌</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">坊,登上观景平台便可将西递古村尽收眼底。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">明经园是西递村保留下来的百年古宅之一,由五个徽派风格院落组成,其中三栋为明清古宅,清雅复古,步步是景。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">每间主卧命名均化用徽州文化元素并融入房间设计。选用慕思床垫、富安娜埃及棉床品、意大利进口MPE乳胶枕、原装进口资生堂洗浴用品,并有全新竹纤维浴巾毛巾、全新亚麻拖鞋、精致的桃木梳,供每一位家人专属使用并可随身带走。</span></span></span></p><p><span style=\"color:#0f294d\"><span style=\"font-size:14px\"><span style=\"background-color:#ffffff\">院内设有集餐厅、咖啡厅、清吧于一体的独栋建筑——泊心餚,让您足不出户即可享受美味佳肴。</span></span></span></p>",
"shopType":4,
"shopTypeText":"民宿",
"shortName":"泊心云舍·明经园",
"status":"ENABLE",
"statusText":"启用",
"tags":"餐厅 行李寄存 无线WIFI 24小时前台",
"tagsList":[
"餐厅",
"行李寄存",
"无线WIFI",
"24小时前台"
],
"updateTime":"2025-03-17 14:27:30"
},
currentIndex: 0,
show: false,
currentTab: 0,
tabs: [
{ name: "选房" },
{ name: "服务" },
{ name: "简介" },
{ name: "评价" },
]
}
},
computed: {
urls () {
if(this.nearShop){
return this.nearShop.imgs.map(item => ({
src: item.url,
desc: item.name || ''
}))
}
return []
}
},
onLoad: function(options) {
const q = options.q

        uni.setNavigationBarTitle({  
            title: this.nearShop.name,  
        });  
        // var that = this;  
        // const eventChannel = this.getOpenerEventChannel();  
        // eventChannel.on('nearShop', function(nearShop) {  
        //  that.nearShop = nearShop;  
        //  that.nearShop.remark =  that.formatRichText(nearShop.remark);  
        //  uni.setNavigationBarTitle({  
        //      title: nearShop.name,  
        //  });  
        //  recordStatVisit({  
        //      relationalId: nearShop.id,  
        //      relationalType: 'NLS_SHOP',  
        //      residentId: getApp().globalData.currentUserResident != null ? getApp().globalData.currentUserResident.id : 0,  
        //  });  
        // });  
    },  
    onReady(){  
        this.getViewportHeight()  
    },  
    methods: {  
        toTelGJ() {  
            if(this.nearShop.hotline){  
                uni.makePhoneCall({  
                    phoneNumber: this.nearShop.hotline.replace(/[^\d]/g,"")     // 替换非数字字符  
                });  
            }  
        },  
        formatRichText(html) {  
          let newContent= html.replace(/\<img/gi, '<img style="max-width:100%;height:auto;display:block;"');  

            // 替换空白p  
            newContent = newContent.replace('<p></p>', '<p style="padding-bottom:1em"></p>')  

          return newContent;  
        },  
        previewImage(index){  
            this.currentIndex = index  
            this.show = true  
        },  
        changeHandler(e){  
            this.currentTab = e.index  
        },  
        swiperChangeHandler(e){  
            this.currentTab = e.detail.current  
        },  
        outerToLowerHandler(){  
            // console.log('toLower-x')  
            // clearTimeout(this.outerTimer)  
            // this.outerTimer = 'EXIT'  
            // setTimeout(() => {  
            //  this.outerTimer = null  
            // }, 400)  
            // this.innerScroll = true  
        },  
        outerScrollHandler(e){  
            console.log(e,e.detail.scrollTop, 'e-x')  
            // if(this.outerTimer === 'EXIT'){  
            //  // scroll 触发的时机不确定,这里是用来终止的  
            //  return   
            // }  
            // clearTimeout(this.outerTimer)  
            // this.outerTimer = setTimeout(() => {  
            //  console.log(e, 'e-x')  
            //  if(e.detail.scrollHeight - this.clientHeight > e.detail.scrollTop){  
            //      this.innerScroll = false  
            //  }  
            // }, 300);  
        },  
        innerToUpperHandler(){  
            clearTimeout(this.innerTimer)  
            this.innerTimer = 'EXIT'  
            setTimeout(() => {  
                this.innerTimer = null  
            }, 400);  
            this.outerScroll = true  
        },  
        innerScrollHandler(e){  
            if(this.innerTimer === 'EXIT'){  
                return  
            }  
            clearTimeout(this.innerTimer)  
            this.innerTimer = setTimeout(() => {  
                console.log(e, 'inner-x')  
                if(e.detail.scrollTop > 0){  
                    this.outerScroll = false  
                }  
            }, 300);  
        },  
        // 获取可视区域高度(兼容小程序和APP)  
        getViewportHeight() {  
            this.clientHeight = uni.getSystemInfoSync().windowHeight  
        }  
    }  
}  

</script>

<style lang="scss" scoped>
.container-wrapper{
font-size: 28rpx;
height: 100%;

.detail-imgs{  
    width: 100%;  
    height: 492rpx;  

    .no-img, swiper{  
        height: 100%;  
    }  

    image{  
        width: 100%;  
        height: 100%;  
    }  
}  

.content{  
    padding: 32rpx 26rpx 40rpx;  
    line-height: 42rpx;  
    background-color: #fff;  
    margin-bottom: 18rpx;  

    .merchant-info{  
        margin-bottom: 30rpx;  

        .name{  
            font-size: 32rpx;  
            font-weight: bold;  
        }  
    }  

    .address-info{  
        background-color: #E9F0F8;  
        border-radius: 8rpx;  
        display: flex;  
        padding: 24rpx 30rpx 24rpx 20rpx;  
        align-items: center;  

        .address{  
            flex-grow: 1;  
            overflow: hidden;  

            .specific-address{  
                color: #909090;  
            }  
        }  

        .map{  
            color: #909090;  
            padding: 0 36rpx;  
            margin-right: 32rpx;  
            display: flex;  
            flex-direction: column;  
            flex-shrink: 0;  
            align-items: center;  
            border-right: 1px solid #D0CECE;  

            image{  
                width: 38rpx;  
                height: 48rpx;  
            }  
        }  

        image{  
            width: 52rpx;  
            height: 52rpx;  
            flex-shrink: 0;  
        }  
    }  
}  

.room-info{  
    display: flex;  
    flex-direction: column;  
    height: 100vh;  

    .content-swiper{  
        padding: 0 26rpx 0;  
        background-color: #fff;  
        flex: 1;  
        scroll-view{  
            height: 100%;  
            .swiper-item-wrapper{  
                padding-bottom: 32rpx;  
            }  
        }  

    }  
}  

}
</style>

操作步骤:

快速滚动一下,利用惯性让scroll-view 滚动到底部。重复几次,会出现

预期结果:

@scrolltoupper 事件触发,@scroll 事件的 e.detail.scrollTop 值准确

实际结果:

@scrolltoupper没有触发,@scroll 事件的 e.detail.scrollTop 不准确

bug描述:

我的项目是uniapp 跨平台项目,微信小程序,app,现在有这么个问题:我真机用手指快速滚动一下,然后手指离开屏幕,此时scroll-view 还在滚动,并且滚动到了底部,但是@scrolltoupper没有触发,并且scroll事件的 e.detail.scrollTop 数据不准确,其实已经滚动到底部,scrollTop是417,但是它给出的是385

2025-03-31 17:19 负责人:无 分享
已邀请:

要回复问题请先登录注册