| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566 | // 小程序无法在hook中使用页面级别生命周期,需单独传入: https://ask.dcloud.net.cn/question/161173// import { onPageScroll, onReachBottom, onPullDownRefresh} from '@dcloudio/uni-app';/**  * 初始化mescroll, 相当于vue2的mescroll-mixins.js文件 (mescroll-body 和 mescroll-uni 通用)  * mescroll-body需传入onPageScroll, onReachBottom * mescroll-uni无需传onPageScroll, onReachBottom * 当down.native为true时,需传入onPullDownRefresh */ function useMescroll(onPageScroll, onReachBottom, onPullDownRefresh){	// mescroll实例对象	let mescroll = null;		// mescroll组件初始化的回调,可获取到mescroll对象	const mescrollInit = (e)=> {		mescroll = e;	}		// 获取mescroll对象, mescrollInit执行之后会有值, 生命周期created中会有值	const getMescroll = ()=>{		return mescroll	}		// 下拉刷新的回调 (mixin默认resetUpScroll)	const downCallback = ()=> {		if(mescroll.optUp.use){			mescroll.resetUpScroll()		}else{			setTimeout(()=>{				mescroll.endSuccess();			}, 500)		}	}		// 上拉加载的回调	const upCallback = ()=> {		// mixin默认延时500自动结束加载		setTimeout(()=>{			mescroll.endErr();		}, 500)	}		// 注册系统自带的下拉刷新 (配置down.native为true时生效, 还需在pages配置enablePullDownRefresh:true;详请参考mescroll-native的案例)	onPullDownRefresh && onPullDownRefresh(() => {	  mescroll && mescroll.onPullDownRefresh();	})		// 注册列表滚动事件,用于判定在顶部可下拉刷新,在指定位置可显示隐藏回到顶部按钮 (此方法为页面生命周期,无法在子组件中触发, 仅在mescroll-body生效)	onPageScroll && onPageScroll(e=>{		mescroll && mescroll.onPageScroll(e);	})		// 注册滚动到底部的事件,用于上拉加载 (此方法为页面生命周期,无法在子组件中触发, 仅在mescroll-body生效)	onReachBottom && onReachBottom(()=>{		mescroll && mescroll.onReachBottom();	}) 		return {		getMescroll,		mescrollInit,		downCallback,		upCallback	}}export default useMescroll
 |