• better-scroll 上拉刷新,下拉加载模板


    npm install better-scroll --save
    <template>
    <div class="tabbar">
    <div ref="wrapper" class="wrapper">
    <div class="content" ref="content">
    <!--上拉的东西-->
    <div class="top">上拉刷新</div>
    <ul>
    <li v-for="item in data" style="line-height:100px">{{item}}</li>
    </ul>
    <!--上拉的东西-->
    <div class="bottom">下拉加载</div>
    </div>
    </div>
    </div>
    </template>

    <script>
    import BScroll from "better-scroll"
    export default {
    data(){
    return {
    data: [0,1,2,3,4,5,6,8,8,8,8,8],
    height:0,
    }
    },
    methods: {
    getData() {
    return new Promise(resolve => { //模拟数据请求
    setTimeout(() => {
    const arr = [];
    for (let i = 0; i < 10; i++) {
    this.data.push(i)
    }
    resolve(arr)
    }, 1000)
    })
    },
    },
    watch: {
    data(val){
    this.$nextTick(() => {
    this.scroll.refresh()
    this.scroll.finishPullUp()
    })
    }
    },
    computed: {

    },
    mounted(){
    this.scroll = new BScroll(this.$refs.wrapper, {
    // 上拉加载
    pullUpLoad: {
    // 当上拉距离超过30px时触发 pullingUp 事件
    threshold: -30
    },
    // 下拉刷新
    pullDownRefresh: {
    // 下拉距离超过30px触发pullingDown事件
    threshold: 30,
    // 回弹停留在距离顶部20px的位置
    stop: 20
    }
    })
    this.scroll.on('pullingUp', () => {
    console.log('处理上拉加载操作')
    this.getData().then(res=>{
    console.log('asfsaf')
    // 事情做完,需要调用此方法告诉 better-scroll 数据已加载,否则下拉事件只会执行一次
    // this.scroll.finishPullUp()
    })
    })
    this.scroll.on('pullingDown', () => {
    console.log('处理下拉刷新操作')
    this.getData().then(res=>{
    // 事情做完,需要调用此方法告诉 better-scroll 数据已加载,否则下拉事件只会执行一次
    this.scroll.finishPullDown()
    })
    })
    }
    }
    </script>

    <style>
    .top{
    position: fixed;
    top:-40px;
    }
    .bottom{
    position: fixed;
    bottom:-40px;
    }
    /*对外层div进行了高度上的限制*/
    .wrapper {
    position: fixed;
    left: 0;
    top: 0;
    bottom: 0;
    100%;
    height:100vh;
    overflow:hidden;
    }
    .content {
    100%;
    /*height:800px;*/
    background:blue;
    }
    </style>
  • 相关阅读:
    面试笔试题目集
    [vs2010]:fatal error C1010: 在查找预编译头时遇到意外的文件结尾。是否忘记了向源中添加“#include "StdAfx.h"”?
    [数据库] SQLite常见问题解答
    安卓学习资料总结39
    Android 学习资料总结40
    python变量的定义和使用
    python运算符
    python的注释
    print输出函数
    python数据类型转换
  • 原文地址:https://www.cnblogs.com/dashaxiong/p/12201897.html
Copyright © 2020-2023  润新知