• 技术文章 >web前端 >js教程

    mescroll.js上拉加载下拉刷新组件详解

    小云云小云云2018-01-19 13:25:27原创1942
    本文主要为大家详细介绍了mescroll.js上拉加载下拉刷新组件的使用,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能帮助到大家。

    使用注意事项:

    1、引入的时候出问题及时看官方给出的解决方案(基本上都必须看);

    2、react中一定要在dom渲染之后的方法(didMount)中初始化,因为这个需要拿到dom对象;

    3、在react工程中,回调的数据一定要拼接,这是要注意的(datas:ctx.state.datas.concat(json.info));

    4、很坑需要单页的里的html和body高度设置100%。

    下边附上简易代码


    import React, { Component, PropTypes } from 'react'; 
    import MeScroll from "mescroll.js" 
     
    class StretchingUp extends Component { 
      constructor(props, context) { 
        super(props, context); 
        this.state={ 
          datas:[], 
          total:0, 
        } 
        this.test = this.test.bind(this); 
      } 
      componentDidMount(){ 
        document.ondragstart=function() {return false;} 
        let ctx = this; 
        var mescroll = new MeScroll ( "mescroll" , {down : { use:false}, up : { 
          use:true, 
          auto:true, 
          offSet:100, 
          page:{ 
            num:0, 
            size:20, 
            time:null 
          }, 
          onScroll:function(mescroll, y, isUp){ 
          }, 
          callback:function (page, mescroll) { 
            ctx.test(page, mescroll); 
          }, 
          error: function (e) { 
          } 
        }} ) ; 
        mescroll.resetUpScroll() 
      } 
      test(page, mescroll){ 
        console.log(page) 
        let url = "http://localhost:5577/curpage/"+page.num+"/pagesize/"+page.size; 
        let ctx = this; 
        fetch(url,{ 
          method:'GET', 
          headers: { 
            'Accept': 'application/json', 
            'Content-Type': 'application/json', 
          }, 
        }).then((resp)=>{ 
          if(resp){ 
            return resp.json(); 
          }else{ 
            return false; 
          } 
        }) 
        .then((json)=>{ 
            ctx.setState({ 
            datas:ctx.state.datas.concat(json.info), 
            total:json.total 
          },()=>{ 
        }) 
     
        mescroll.endSuccess(); 
        return true; 
      }); 
      } 
      render() { 
        return ( 
          <p id="mescroll" className="mescroll" style={{height: "500px",overflow: "auto"}}> 
          {this.state.datas.map((item,index)=>( 
            <p key={index}> 
              {item.id} 
            </p> 
          ))} 
          </p> 
      ); 
      }} 
     
    export default StretchingUp;

    相关推荐:

    微信小程序开发列表上拉加载下拉刷新示例代码

    dropload.js插件下拉刷新和上拉加载方法

    实例详解mui上拉加载更多下拉刷新数据的封装过程

    以上就是mescroll.js上拉加载下拉刷新组件详解的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    上一篇:jQuery点击任何地方隐藏DIV功能 下一篇:HBuilder打包webapp为apk的方法
    PHP编程就业班

    相关文章推荐

    • 你能搞懂JS的this指向问题吗?看看这篇文章• 浅析react18中的新概念Transition• 什么是事件循环?详解Node.js中的事件循环• javascript跨域的原因是什么• 一起来分析JavaScript五大事件

    全部评论我要评论

  • 取消发布评论发送
  • 1/1

    PHP中文网