发布于 2016-06-18 05:04:50 | 94 次阅读 | 评论: 0 | 来源: 网友投递

这里有新鲜出炉的精品教程,程序狗速度看过来!

ASP.NET

ASP.NET 是.NET FrameWork的一部分,是一项微软公司的技术,是一种使嵌入网页中的脚本可由因特网服务器执行的服务器端脚本技术,它可以在通过HTTP请求文档时再在Web服务器上动态创建它们。 指 Active Server Pages(动态服务器页面) ,运行于 IIS(Internet Information Server 服务,是Windows开发的Web服务器)之中的程序 。


AJAX(Asynchronous JavaScript and XML)是一种进行页面局部异步刷新的技术。用AJAX向服务器发送请求和获得服务器返回的数据并且更新到界面中,不是整个页面刷新,而是在页面中使用Js创建XMLHTTPRequest对象来向服务器发出请求以及获得返回的数据。

查询功能是开发中最重要的一个功能,大量数据的显示,我们用的最多的就是分页。

在ASP.NET 中有很多数据展现的控件,比如Repeater、GridView,用的最多的GridView,它同时也自带了分页的功能。但是我们知道用GridView来显示数据,如果没有禁用ViewState,页面的大小会是非常的大的。而且平时我们点击首页,下一页,上一页,尾页这些功能都是会引起页面回发的,也就是需要完全跟服务器进行交互,来回响应的时间,传输的数据量都是很大的。

AJAX的分页可以很好的解决这些问题。

数据显示Pasing.aspx页面JS代码:  



<script type=text/javascript>

       var pageIndex = 0;

       var pageSize = 5;

window.onload = AjaxGetData(name,0,5);

function AjaxGetData(name, index, size){

        $.ajax({

            url: jQueryPaging.aspx,

            type: Get,

            data: Name= + name + &PageIndex= + index + &PageSize= + size,

            dataType: json,

            success: function (data) {

                var htmlStr = ;

                htmlStr += 

                htmlStr += 

                htmlStr += 

                htmlStr += ;

                htmlStr +=    //data.cloudfileLists.length

                for (var i = 0; i < data.cloudfileLists.length; i++) 

                {

                    htmlStr += ;

                    htmlStr += 

                                      + 

                    htmlStr += ;

                }

                htmlStr += ;

                htmlStr += ;

                htmlStr += ;

                htmlStr += ;

                htmlStr += ;

                htmlStr += ;

                htmlStr += <table><thead><tr><td>编号</td><td>文件名</td></tr></thead><tbody><tr><td> + data.cloudfileLists[i].FileID + </td><td> + data.cloudfileLists[i].FileName + </td></tr></tbody><tfoot><tr><td colspan="'6'">;

                htmlStr += <span>共有记录 + data.Count + ;共<span id="'count'"> + (data.Count % 5 == 0 ? parseInt(data.Count / 5) : parseInt(data.Count / 5 + 1)) + </span>页 + </span>;

                htmlStr += 首    页   ;

                htmlStr += 前一页   ;

                htmlStr += 后一页   ;

                htmlStr += 尾    页   ;

                htmlStr += <input type="'text'"><input type="'button'" value="'跳转'" onclick="'GoToAppointPage(this)'"> ;

                htmlStr += </td></tr></tfoot></table>;

 

                $(#divSearchResult).html(htmlStr);//重写html

            },

            error: function (XMLHttpRequest, textStatus, errorThrown) {

                alert(XMLHttpRequest);

                alert(textStatus);

                alert(errorThrown);

            }

        });

    }

    //首页

    function GoToFirstPage() {

        pageIndex = 0;

        AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);

    }

    //前一页

    function GoToPrePage() {

        pageIndex -= 1;

        pageIndex = pageIndex >= 0 ? pageIndex : 0;

        AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);

    }

    //后一页

    function GoToNextPage() {

        if (pageIndex + 1 < parseInt($(#count).text())) {

            pageIndex += 1;

        }

        AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);

    }

    //尾页

    function GoToEndPage() {

        pageIndex = parseInt($(#count).text()) - 1;

        AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);

    }

    //跳转

    function GoToAppointPage(e) {

        var page = $(e).prev().val();

        if (isNaN(page)) {

            alert(请输入数字!);

        }

        else {

            var tempPageIndex = pageIndex;

            pageIndex = parseInt($(e).prev().val()) - 1;

            if (pageIndex < 0 || pageIndex >= parseInt($(#count).text())) {

                pageIndex = tempPageIndex;

                alert(请输入有效的页面范围!);

            }

            else {

                AjaxGetData($(#txtSearch).val(), pageIndex, pageSize);

            }

        }

    }

</script>

同一页面HTML代码:

jQueryPaging.aspx页面的CS代码如下:

引用这个命名空间:using System.Web.Script.Serialization;//JavaScriptSerializer要用的。



protected void Page_Load(object sender, EventArgs e)

{

    Int32 pageIndex = Int32.MinValue;

    Int32 pageSize = Int32.MinValue;

    String name = String.Empty;

    JavaScriptSerializer jss = new JavaScriptSerializer();

    if (Request[Name] != null)

    {

        name = Request[Name].ToString();

        if (Request[PageIndex] != null)

        {

            pageIndex = Int32.Parse(Request[PageIndex].ToString());

            pageSize = Request[PageSize] != null ? Int32.Parse(Request[PageSize].ToString()) : 5;

            IList<cloudfile> cloudfileLists = new List<cloudfile>();//cloudfile是自己写的类,表示一条数据</cloudfile></cloudfile>

            CloudFile cf = null;
            int cout = 0;
            DataSet ds = LookDataFromDB(name, pageIndex, pageSize,out cout);
            foreach (DataRow row in ds.Tables[0].Rows)//把你的数据重新封装成Lis,才能被jss.Serialize(),不然会报错。
            {
                cf = new CloudFile();
                cf.FileID = row[FilePathId].ToString();
                cf.FileName = row[FileName].ToString();
                cloudfileLists.Add(cf);
            }
            if (cloudfileLists.Count > 0)
            {
                Response.Write({Count: + (cout) + ,cloudfileLists: + jss.Serialize(cloudfileLists) + });
                Response.End();
            }
        }
    }
}
private DataSet LookDataFromDB(string name, int pageIndex, int pageSize,out int cout)
{
    DataSet ds = new DataSet();
    try
    {
        pageIndex = 5 * pageIndex;//pageIndex ,表示这一页从哪一条数据开始
       // 这里写自己的数据获取方法,把数据获取好了甩到ds里面,返回到前面。(应该有更好的办法,自己想哦,也可以发评论我们一起探讨....。)
    }
    catch (Exception)
    {
        cout = 0;
        ds = null;
    }
    return ds;
}



//<span style="font-family:">CloudFile类</span>



    public class CloudFile

    {

        public String FileID { get; set; }

        public String FileName { get; set; }

        public String FileDirName { get; set; }

    }

这样一个简单的无刷新分页的实例就完成了。由于本人的JS水平有限,现在只能做到这了。当然还可以添加一些新的功能。这里我只是想将我的方法与大家分享。至于功能,待以后继续完善了!!!



最新网友评论  共有(0)条评论 发布评论 返回顶部

Copyright © 2007-2017 PHPERZ.COM All Rights Reserved   冀ICP备14009818号  版权声明  广告服务