首 页 网络编程
网页制作 图形图象 操作系统 冲浪宝典
软件教学 认证考试

网络安全 网络办公 行业资讯 评测对比
您当前位置:站长天空 -> 网页制作-> Javascript教程
利用jquery方便实现基于ajax的数据查询、排序和分页功能_ajax教程
作者:网友供稿 点击:0
推荐
西部数码-全国虚拟主机10强!20余项虚拟主机管理功能,全国领先!第6代双线路虚拟主机,南北访问畅通无阻!可在线rar解压,自动数据恢复设置虚拟目录等.免费赠送访问统计,企业邮局.Cn域名注册10元/年,自助建站480元起,免费试用7天,满意再付款!P4主机租用799元/月.月付免压金
站内搜索
文章页数:[1] 

       之前很少会用JavaScript去实现页功能主要怕麻烦,但了解JQuery后这种想法发生了变化;有了这样的脚本组件就可以在编写脚本时方便和HTML隔离出来,这样编写高重用性的脚本就更方便。下面就是介绍在学习JQuery过程中编写的基于Ajax的数据查询、排序和分页功能的复用脚本,只要遵循脚本的某些规则描述HTML把脚本文件引入就可以方便实现以上描述的功能。

       先看下实现功能的脚代码:

/**应用脚本规则:

          引用脚本: JQuery脚本和JQuery的form插件脚本

          Form的ID:    viewform

    显示数据的div的ID: listview

     分页按钮HTML属性: pageindex="1"

     排序按钮HTML属性: orderfield="employeeid desc";

提效排序字段Input的ID,Name: orderfield

提交分页索引Input的ID,Name: pageindex

**/

function onInitPaging()

{

     $("#listview").find("[@orderfield]").each(function(i)

        {

            var ordervalue = $(this).attr("orderfield");

            $(this).click(function()

                {

                    $("#orderfield").val(ordervalue);

                    onSubmitPage();

                }

            );

        }

    );

    $("#listview").find("[@pageindex]").each(function(i)

        {

            var piValue = $(this).attr("pageindex");

            $(this).click(function()

                {

                    $("#pageindex").val(piValue);

                    onSubmitPage();

                }

            );

        }

    );

}

function onSubmitPage()

{

    var options = {

        success: function SubmitSuccess(data){

            $("#listview").html(data);

            onInitPaging();

          

        }

    };

    $(#viewform).ajaxSubmit(options);

}

$(document).ready(

    function()

    {

        $("#search").click(function(){

        $("#pageindex").val(0);

        onSubmitPage()

       

        });

      onSubmitPage();

    }

);

约束规则巧用了html的自定义属性,以上代码描述查询,排序和分页的ajax提交处理。在编写HTML时只需要遵循描述的规则即可,你并不需要在编写任何脚本代码;只需要把脚本添加到页面里:
http://www.knowsky.com
    <script src=jquery-latest.js></script>

    <script src=form.js></script>

    <script src=calendar.js></script>

     <script src=calendar-setup.js></script>

    <script src="http://www.knowsky.com/lang/calendar-en.js"></script>

    <script src=pagination.js></script>

    <form id="viewform"  method="post" action="FrmOrderView.aspx">

    <input id="orderfield" name="orderfield" type="hidden" value="" />

    <input id="pageindex" name="pageindex" type="hidden" value ="0"/>

    <table border="0" cellpadding="0" cellspacing="0" style="width: 100%; height: 100%">

            <tr>

                <td valign="top" align="left">

                     <table width="550" cellpadding="0" cellspacing="0">

                        <tr>

                            <td style="width: 63px; height: 17px; background-color: gainsboro;">

                                CompanyName</td>

                            <td style="width: 114px; height: 17px;">

                                <input id="Text1" name="companyname" type="text" /></td>

                            <td style="width: 63px; height: 17px; background-color: gainsboro;">

                                ShipCity</td>

                            <td style="width: 126px; height: 17px;">

                                <input id="Text2" name="shipcity" type="text" /></td>

                        </tr>

                        <tr>

                            <td style="width: 63px; height: 14px; background-color: gainsboro;">

                                OrderDate</td>

                            <td style="width: 240px; height: 14px;" align="left">

                                <input id="Text3" name="OrderDate_Begin" type="text" />

                                <input id="button1" DateField="Text3" type="button" value="..." /></td>

                            <td style="width: 63px; height: 14px; background-color: gainsboro;">

                            </td>

                            <td style="width: 240px; height: 14px;" align="left">

                                <input id="Text4" type="text" name="OrderDate_End" />

                                <input id="button2" DateField="Text4" type="button" value="..." /></td>

                        </tr>

                        <tr>

                            <td style="height: 50px" align="left" colspan="4">

                                <input id="search" type="button" value="Search" /></td>

                        </tr>

                    </table>

                </td>

            </tr>

            <tr>

                <td height="99%">

                <div id="listview"></div>

                </td>

            </tr>

        </table>

     </form>


数据提供页面:


<%@ Page Language="C#" AutoEventWireup="true" Inherits="HFSoft.MVC.DataViewContext" %>

<%@ Import Namespace="NorthWind.Entities" %>

<%

    HFSoft.MVC.IDataViewContext dataview = (HFSoft.MVC.IDataViewContext)this;

 %>

<table width="100%" >

   <% if(dataview.PageCount >0){%>

    <tr>

        <td colspan="7" style="height: 20px">

        <a href="#" pageindex="0" >首页</a>

        <a href="#" pageindex="<% =dataview.PrevPage%>">上一页</a>

        <a href="#" pageindex="<% =dataview.NextPage %>" >下一页</a>

        <a href="#" pageindex="<% =dataview.PageCount-1%>">末页</a>

        当前<%=dataview.PageIndex+1%>页/共<%=dataview.PageCount %>页

        </td>

    </tr>

 

    <%}%>

    <tr>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            <a href="#" orderfield="<%=dataview.GetOrderInfo("CompanyName")%>" >CustomerName</a></td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            <a href="#" orderfield="<%=dataview.GetOrderInfo("Employees.EmployeeID")%>" >EmployeeName</a></td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            <a href="#" orderfield="<%=dataview.GetOrderInfo("OrderDate")%>" >OrderDate</a></td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            <a href="#" orderfield="<%=dataview.GetOrderInfo("RequiredDate")%>" >RequireDate</a></td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            ShipAddress</td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            ShipCity</td>

        <td style="width: 100px; font-weight: bold; background-color: activeborder;">

            SipCountry</td>

    </tr>

    <%foreach(Order_v item in dataview.DataItems)

      { %>

    <tr>

        <td style="width: 100px"><%=dataview.ToValue(item.CustomerName)%>

        </td>

        <td style="width: 100px"><%=dataview.ToValue(item.EmployeeName)%>

        </td>

        <td style="width: 100px"><%=dataview.ToValue(item.OrderDate, "{0:d}")%>

        </td>

        <td style="width: 100px"><%=dataview.ToValue(item.RequiredDate, "{0:d}")%>

        </td>

        <td style="width: 100px"><%=dataview.ToValue(item.ShipAddress)%>

        </td>

        <td style="width: 100px"><%=dataview.ToValue(item.ShipCity)%>

        </td>

        <td style="width: 100px"><% =dataview.ToValue(item.ShipCountry)%>

        </td>

    </tr>

   

     <% } %>

  

</table>


数据提供页相关Controller代码:


[HFSoft.MVC.FormMapper("~/frmorderview.aspx")]

public void OrderView()

{

    HFSoft.MVC.IDataViewContext viewcontext = (HFSoft.MVC.IDataViewContext)this.FormContext;

    IExpression exp;

    FieldAdapter[] orderby = null;

    OrderSearch search = viewcontext.BindObject<OrderSearch>();

    exp = search.GetExpression();

    if (viewcontext.OrderField != null && viewcontext.OrderField != string.Empty)

    {

        orderby = new FieldAdapter[]{new FieldAdapter(viewcontext.OrderField, null)};

    }

    Region region = new Region(viewcontext.PageIndex * 10, viewcontext.PageIndex * 10+10);

    viewcontext.DataItems = exp.List<Order_v>(region, orderby);

    viewcontext.PageSize = 10;

    viewcontext.RecordCount = exp.CountOf<Order_v>();

}

下载例程代码和脚源码:http://www.cnblogs.com/Files/henryfan/AjaxSearchDataSample.rar


文章整理:站长天空 网址:http://www.z6688.com/
以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

文章页数:[1] 


放大字体显示 缩小字体显示 打印文章 推荐给朋友
热门文章
·基于cpld的数字触发电路的设计
·消息队列(Message Queue)简介及其使用-.NET教程,评论及其它
·session_register()出错的解决办法-PHP教程,其它文章
·卫星通信中tcp协议分析改进方法研究
·漫谈Java语言的接口与类型安全-JSP教程,Java技巧及代码
·SQL SERVER2005連接字串中的@3/29-.NET教程,数据库应用
·自创]JCreator安装学习使用方法-数据库专栏,SQL Server
·ASP.NET 数据绑定常用代码-.NET教程,Asp.Net开发
·如何在J2ME的低级界面中轻松实现各种文字的自然分行显示-JSP教程,J2ME开发
·通信设备pac模块式开关电源的原理与维修
最新文章
·photoshop将肖像照片处理为铅笔素描_photoshop教程
·个人网站做联盟广告的几点经验_网赚技巧
·适合与不适合做google adsense的站_网赚技巧
·gg网赚之:怎么样利用e文站轻松月入100刀_网赚技巧
·黄明明归国创业寻觅伙伴:人品好是必要条件_站长访谈
·最普通的7种软文类型_站长访谈
·第九城市ceo朱骏 网海中闯出一片天_站长访谈
·反波访谈:听keso乱弹琴_站长访谈
·人性和互联网_站长心得
·大型网站常用的五种推广方法_站长心得
相关主题
西部数码虚拟主机

友情链接
CNNIC 西部数码
万网 自助建站
虚拟主机 asp空间
域名注册 域名
域名申请 主页空间
论坛空间 网站空间
国际域名 虚拟空间
空间租用 DDOS防火墙
成都主机托管 四川主机托管
主机租用 服务器租用
网站目录 自助建站
虚拟主机 网址大全
软件下载
自助链接
虚拟主机资讯 特价虚拟主机
版权申明:本站文章均来自网络,如有侵权,请联系我们,我们收到后立即删除,谢谢!
关于我们:站长天空:专业提供最新的站长资讯、在线教程、虚拟主机权威评测、虚拟主机性能对比、网站制作教程,开发教程,站长工具。包括网页制作教程、冲浪宝典、编程参考、操作系统、软件教学、行业动态等。
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有。
发表评论 打印  刷新     关闭