zoukankan      html  css  js  c++  java
  • AutoPager的简单实现

    Firefox有个自动翻页的插件AutoPager,使用起来非常的方便。腾讯微博也有相同的功能,当鼠标滑动到底部时会自动展开下一页,如下图所示:

    展开后如下所示:

    这个功能虽然比较小,但是实现起来是非常有意思的事情,我们可以选择多种方法达到目的。下面我介绍一种简单的实现方式。

    1、首先移动滚动条会触发window.onscroll事件。

    2、我们可以根据滚动条滚动时屏幕位置和页面底部的距离来判断是否需要翻页。

    需要用到三个函数:

    1、pageHeight:页面总高度。

    2、windowHeight:屏幕高度。

    3、ScollY:页面滚动的高度。

    pageHeight减去windowHeight减去ScollY即为当前屏幕底部到页面底部的距离,如下图所示:

    下面我们可以来实现这个功能了,我们设置一个阈值来设定页面加载的次数。

    这样,我们就实现了AutoPager的功能。

    剩下一个很有意思的问题,window.onscroll按照道理会在滚动条的每次移动时触发,那么在我们设定触发的高度内(例子里是60个像素),它会不会频繁的调用我们的方法呢?例如像腾讯微博一样的Ajax调用会不会多次出现呢?又该如何解决此问题呢?读者有空的话可以思考思考。

  • 相关阅读:
    模块(module)
    编译和解释性语言和python运行方式
    管道通信初级
    Page.TryUpdateModel 方法
    运用模型绑定和web窗体显示和检索数据(Retrieving and displaying data with model binding and web forms)
    HttpResponse 类
    ASP.NET中IsPostBack详解
    3.4.1 使用过滤式扩展方法(P43-44)
    使用扩展方法(Chapter3 P39-41)
    C#对象初始或器-Chapter3 P38
  • 原文地址:https://www.cnblogs.com/javawebsoa/p/2458307.html
Copyright © 2011-2022 走看看