jquery.infinitescroll中文配置API及示例

jquery.infinitescroll中文配置API,翻译和理解上有些小bug,欢迎指正。。~

    $.infinitescroll.defaults = {
        loading: {//加载信息显示配置
            finished: undefined, //每次加载完数据的回调函数,参数:配置对象。回调函数中的this为选择器选择的DOM对象。注意要自己实现加载信息的隐藏
            //全部加在完毕后显示的信息
            finishedMsg: "<em>Congratulations, you've reached the end of the internet.</em>",
            //默认加载数据时显示的等待图片
            img: "",
            msg: null, //加载数据时显示的信息,传递这个会替换掉默认的信息,就是替换掉img和msgText配置的信息。注意为jquery对象
            msgText: "<em>Loading the next set of posts...</em>",//默认加载数据时的提示信息
            selector: null,//将等待显示现在在那个容器里面,不传递则显示在内容容器中
            speed: 'fast', //隐藏或者显示等待内容的时间间隔
            //每次开始加载数据的回调函数,参数和this对象和finished一样。
            //建议不要传递start配置,参考了它默认的start,有发送ajax请求的代码,自己写start函数如何触发请求ajax比较麻烦。
            //默认start事件如下。一定要传递这个参数具体看示例如何处理
            /*opts.loading.start = opts.loading.start || function() {
                $(opts.navSelector).hide();
                opts.loading.msg
                .appendTo(opts.loading.selector)
                .show(opts.loading.speed, $.proxy(function() {
					this.beginAjax(opts);
				}, self));
            };*/
            start: undefined
        },
        state: {//记录状态用,不用配置,一般只读的
            isDuringAjax: false,//是否ajax请求加载中
            isInvalidPage: false,//指定的url是否正确
            isDestroyed: false,//实例是否已经注销
            isDone: false, // 是否已经全部加载完毕
            isPaused: false,//是否暂停加载
            currPage: 1//加载第几页了
        },
        debug: false,//是否在控制台显示调试信息
		behavior: undefined,
		binder: $(window), // used to cache the selector
		//下一个加载页面的链接对象选择器,分页从链接对象中获取href属性分析出来的
		//链接对象href可以类似 xxx/xxx/page/2这种或者xxx/xxx/xxx.aspx?page=这种,需要有page内容
        //也可以传递path配置
        nextSelector: "div.navigation a:first",
        navSelector: "div.navigation",//导航容器
        contentSelector: null, // rename to pageFragment,内容容器选择器,一般不需要配置。配置了会替换掉调用innfinitescroll方法的对象作为容器
        extraScrollPx: 150, //animate为true时有效,显示内容效果结束后向下滚动滚动条多少距离
        itemSelector: "div.post",//从ajax返回的内容中选出需要的内容,一定要配置对,要不获取不到数据
        animate: false,//显示内容是否增加动画效果
        pathParse: undefined,
        dataType: 'html',//返回的数据类型
        appendCallback: true,
        bufferPx: 40,
        errorCallback: function () { },//加载错误的回调
        infid: 0, //Instance ID
        pixelsFromNavToBottom: undefined,
        //路径配置,可以为数组或者一个方法,为方法时参数为下一个加载的页码。
        path: undefined, // Either parts of a URL as an array (e.g. ["/page/", "/"] or a function that takes in the page number and returns a URL
		prefill: false, // When the document is smaller than the window, load data until the document is larger or links are exhausted
        maxPage: undefined // to manually control maximum page (when maxPage is undefined, maximum page limitation is not work)最大加载的页数,从数据库中计算得到
	};

DEMO

<meta http-equiv="content-type" content="text/html;charset=utf-8" />
<h1>本地file浏览测试时使用firefox或者ie,不要用chrome,webkit核心浏览器无法访问除自身外的本地资源<br />
静态页作为数据源最好编码为utf-8,要不会乱码<br />
使用gb2312编码时,动态页输出内容设置下charset为gb2312<br />
asp/asp.net,其他语言自己找下资料<br />
response.charset="gb2312"<br />
Response.Charset="gb2312";
</h1>
<script type="text/javascript" src="../../js/jquery.js"></script>
<script src="jquery.infinitescroll.dev.js"></script>
<script>
    $(function () {
        $('#content').infinitescroll({
            loading: {
                finished: function () { $('#loading').hide(); }
                , start: function (opts) { //不建议传递start,需要多些很多代码
                    var me = $(this);
                    $('#loading').show($.proxy(function () {
                        //获取缓存的对象,注意是在DOM对象上缓存的,不是jquery包装过后的
                        $.data(this[0], 'infinitescroll').beginAjax(opts) ; 
                    }, me));//注意使用me对象更改上下文
                }
                , msg: $('#loading')
            }
        , navSelector: '#paging'
        , nextSelector: '#paging a'
        , itemSelector: 'div.item'
        , maxPage: 4
        ,animate:true
        , path: function (page) { return page + '.html' }
        }, function () { });
    });
</script>
<div id="content">
<div class="item">
第一页内容第一页内容<br>  
第一页内容<br>第一页内容<br>第一页内容<br>  
第一页内容<br>第一页内容<br>第一页内容<br>  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
第一页内容<br>第一页内容<br>第一页内容  
</div>
</div>
<div id="loading" style="display:none">loading..</div>
<div id="paging"><a href="1.html"></a></div>

 


分类:Ajax示例源代码 下载地址
阅读(1508)喜欢(1)28.15KB浏览器 点击下载