vue 使用better-scroll实现上下拉加载效果
安装插件
npm install better-scroll --save
页面使用
<script>
import Bscroll from "better-scroll";
export default {
data() {
return {
isPullDown: false,
pageNo: 1, //当前页
pageSize: 20, //每页显示
totalPage: "", //总页数
totalNo: "", //总条数
options: {
click: true,//解决页面点击事件不触发
scrollY: true,
pullDownRefresh: {
threshold: 30, //下拉距离超过30px触发pullingDown事件
stop: 20 / 回弹停留在距离顶部20px的位置
}
}
}
},
created() {
this.list();
},
mounted() {
this.$nextTick(() => {
this.initScroll();
});
},
methods: {
initScroll() {
this.myScroll = new Bscroll(".box",this.options);
// this.myScroll = new Bscroll(".mytask_main", { mouseWheel: true, click: true, tap: true });
// 上拉加载
this.pullDownEvent();
// 下拉刷新
this.pullUpLoadEvent();
},
finishPulling() {
this.myScroll.finishPullDown(); // 结束下拉刷新
this.myScroll.finishPullUp(); // 结束上拉加载更多
this.myScroll.refresh(); // dom节点变化,重新计算better-scroll
},
pullDownEvent() {
this.myScroll.on("pullingDown", () => {
this.isPullDown = true;
console.log("下拉刷新");
this.pageNo = 1;
this.getList();
});
},
pullUpLoadEvent() {
this.myScroll.on("pullingUp", () => {
console.log("上拉加载");
if (this.pageNo < this.totalPage) {
this.pageNo++;
this.getList();
} else {
this.isPullDown = false;
}
});
},
getList(){
let _this=this
let data={
//请求的参数
}
reqUrl(this,data).then(res=>{
_this.pageNo = res.body.pageNo;
_this.totalPage = res.body.totalPage;
if (_this.pageNo != 1) {
// 不是第一页,要拼接上一页的数据
_this.list = _this.list.concat(res.body.list);
if (_this.pageNo != res.body.totalPage) {
_this.isPullDown = true;
}
} else {
// 第一页
_this.list = res.body.list;
}
_this.$nextTick(() => {
_this.finishPulling();
});
}).catch(err=>{
console.log(err)
})
}
}
}
</script>