asp.net webform 自定义分页控件

发布时间:2019-08-30  栏目:sqlite  评论:0 Comments

   
 作者使用asp.net的webform框架实行web应用程序的支出已经基本上八年了,在漫天开采生涯中,也利用过一年asp.net的mvc框架。因为网络时一时有研讨webform框架和mvc框架的好坏,所以本人也对这两个实行了关爱,因为本人最熟知webform框架,所以就能虚拟它的优势是哪些?设计思路是哪些?

做web开垦直接用到分页控件,自身也入手实现了个,使用顾客自定义控件。

   
要明白asp.net的安插思路,必得思量它的爆发时期,发生的技艺基础,还恐怕有观望同期代其余动态网页工夫的特色和笔触。

翻页后数据加载使用委托,将切实贯彻放在在采取分页控件的页面进行挂号。

   首先是发出asp.net的才干基础,以下援用百度百科:

有图有本质,给个直观的认知:

*   “壹玖玖捌年,ASP 1.0(Active Server
Pages)版本出现了,它引起了Web开采的新革命,裁减了动态网页开采的难度。从前开辟动态网页须要编写制定多量繁杂的C代码,编制程序功用非常的低下,并且亟需Web网页开辟者明白异常高的编制程序技艺。而ASP使用简易的脚本语言,能够将代码直接嵌入HTML,使设计Web页面变得更简明。尽管ASP特别简单,但却能够落到实处充足有力的功力,这整个得益于其组件。特别是ADO组件,使得在网页中访谈数据库稳操胜算。那总体推动了动态网页的飞快进步与建设,同一时间使ASP得到迅捷盛行。*

图片 1

*    1999年,微软公司发布了ASP 2.0,它是当做Windows NT 4 Option
Pack的一局地提供的。ASP 2.0与ASP
1.0的严重性差距是外界的零部件能够初始化,使全体的机件都有了独自的内部存款和储蓄器空间,而且能够开展事务管理。内置的Microsoft
Transaction Server(MTS)使制作零部件变得更易于。*

自定义分页控件前台代码:

*   
三千年14月,微软集团发表了协和的.NET框架。.NET框架的基本思维是:把原本的主要性从三番五次到互连网的单一网址或设施转移到Computer、设备和劳务群组上,而将网络自己作为新一代操作系统的基础。那样,客商将能够决定音信的传递形式、时间和剧情,进而获得越来越多的劳动。*

<style type="text/css">    .pager-m-l {        margin-left: 10px;    }    .pager {        font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;        font-size: 14px;        color: #333;        background-color: #fff;        text-align: center;        border: 1px solid #eee;        border-radius: 5px;        height: 30px;        line-height: 30px;        margin: 10px auto;        width: 650px;    }    .font-blue {        color: #5bc0de;    }    .pager a {        color: #5bc0de;        text-decoration: none;    }        .pager a.gray {            color: #808080;        }    .pager-num {        width: 30px;        text-align: center;    }    .pager-form-control {        color: #555;        background-color: #fff;        background-image: none;        border: 1px solid #ccc;        border-radius: 4px;        -webkit-box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);        box-shadow: inset 0 1px 1px rgba(0, 0, 0, .075);        -webkit-transition: border-color ease-in-out .15s, -webkit-box-shadow ease-in-out .15s;        -o-transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;        transition: border-color ease-in-out .15s, box-shadow ease-in-out .15s;        padding: 2px 0px;        margin: 0px 2px;    }        .pager-form-control:focus {            border-color: #66afe9;            outline: 0;            -webkit-box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);            box-shadow: inset 0 1px 1px rgba(0,0,0,.075), 0 0 8px rgba(102, 175, 233, .6);        }    .btn {        display: inline-block;        padding: 2px;        font-weight: normal;        text-align: center;        white-space: nowrap;        vertical-align: middle;        -ms-touch-action: manipulation;        touch-action: manipulation;        cursor: pointer;        -webkit-user-select: none;        -moz-user-select: none;        -ms-user-select: none;        user-select: none;        background-image: none;        border: 1px solid transparent;        border-radius: 4px;    }    .btn-default {        color: #333;        background-color: #fff;        border-color: #ccc;    }</style><div class="pager">    当前<asp:Label runat="server" ID="labCurrentPageIndex" CssClass="font-blue"></asp:Label>/<asp:Label runat="server" CssClass="font-blue" ID="labTotalNumberOfPages"></asp:Label>页    共<asp:Label runat="server" CssClass="font-blue" ID="labRecordCount"></asp:Label>条记录            <asp:LinkButton runat="server" ID="labFirstPage" OnClick="labFirstPage_Click">首页</asp:LinkButton>        |        <asp:LinkButton runat="server" ID="labPreviousPage" OnClick="labPreviousPage_Click">上一页</asp:LinkButton>        |<asp:LinkButton runat="server" ID="labNextPage" OnClick="labNextPage_Click">下一页</asp:LinkButton>        |<asp:LinkButton runat="server" ID="labLastPage" OnClick="labLastPage_Click">尾页</asp:LinkButton>        跳至<asp:TextBox runat="server" ID="txtPageNum" CssClass="pager-form-control pager-num">1</asp:TextBox>页        <asp:Button runat="server" Text="GO" ID="btnGo" CssClass="btn btn-default" OnClick="btnGo_Click" />            <asp:DropDownList runat="server" ID="ddlPageSize" CssClass="pager-form-control" AutoPostBack="true" OnSelectedIndexChanged="ddlPageSize_SelectedIndexChanged">            <asp:ListItem Text="10" Value="10"></asp:ListItem>            <asp:ListItem Text="20" Value="20"></asp:ListItem>            <asp:ListItem Text="30" Value="30"></asp:ListItem>            <asp:ListItem Text="50" Value="50"></asp:ListItem>            <asp:ListItem Text="100" Value="100"></asp:ListItem>        </asp:DropDownList>条/每页</div>

*   
二〇〇四年,ASP.NET浮出水面。它最早的名称叫ASP+,后来改为ASP.NET。ASP.NET是微软公司开拓的一种创立在.NET之上的Web运营景况,它不是ASP的简短进级,而是新一代的Active
Server
Pages。ASP.NET是微软公司新体系布局Microsoft.NET的一片段,当中全新的手艺架构使编制程序变得尤为简便易行。借助于ASP.NET,能够创立出内容丰盛的、动态的、本性化的Web站点。ASP.NET轻便易学、功用强大、应用灵活、扩展性好,能够利用任何.NET包容语言。 [4-5] *

自定义分页控件后台代码:

*    2004年微软公布.NET正式版本.NET Framework
1.0,个中的ASP版本正是ASP.NET
1.0,在此在此之前发布了三个.NET测验版本Betal和Beta2。*

private const string viewStateCurrentPageIndex = "CurrentPageIndex";        private const string viewStateRecordCount = "RecordCount";        public delegate void PageChangedHandle();        public event PageChangedHandle OnPageChanged;        public int PageSize        {            get            {                return Convert.ToInt32(ddlPageSize.SelectedValue);            }        }        public int CurrentPageIndex        {            set            {                ViewState[viewStateCurrentPageIndex] = value;            }            get            {                if (ViewState[viewStateCurrentPageIndex] == null)                {                    ViewState[viewStateCurrentPageIndex] = 1;                }                return Convert.ToInt32(ViewState[viewStateCurrentPageIndex]);            }        }        public int RecordCount        {            get            {                if (ViewState[viewStateRecordCount] == null)                {                    ViewState[viewStateRecordCount] = 0;                }                return Convert.ToInt32(ViewState[viewStateRecordCount]);            }            set            {                ViewState[viewStateRecordCount] = value;            }        }        private int TotalNumberOfPages        {            get            {                return RecordCount % PageSize == 0 ? RecordCount / PageSize : (RecordCount / PageSize) + 1;            }        }        protected void Page_Load(object sender, EventArgs e)        {            if (!IsPostBack)            {            }        }        protected void labFirstPage_Click(object sender, EventArgs e)        {            CurrentPageIndex = 1;            this.DataBind();        }        protected void labPreviousPage_Click(object sender, EventArgs e)        {            CurrentPageIndex -= 1;            this.DataBind();        }        protected void labNextPage_Click(object sender, EventArgs e)        {            CurrentPageIndex += 1;            this.DataBind();        }        protected void labLastPage_Click(object sender, EventArgs e)        {            CurrentPageIndex = TotalNumberOfPages;            this.DataBind();        }        protected void btnGo_Click(object sender, EventArgs e)        {            int pageNum = 1;            bool isNum = Int32.TryParse(txtPageNum.Text, out pageNum);            if             {                CurrentPageIndex = Math.Min(pageNum, TotalNumberOfPages);            }            this.DataBind();        }        protected void ddlPageSize_SelectedIndexChanged(object sender, EventArgs e)        {            CurrentPageIndex = 1;            this.DataBind();        }        protected override void DataBind(bool raiseOnDataBinding)        {            BindPager();            base.DataBind(raiseOnDataBinding);            if (OnPageChanged != null)            {                OnPageChanged();            }        }        private void BindPager()        {            labCurrentPageIndex.Text = CurrentPageIndex.ToString();            labTotalNumberOfPages.Text = TotalNumberOfPages.ToString();            labRecordCount.Text = RecordCount.ToString();            SetNavigateEnabled();        }                private void SetNavigateEnabled()        {            txtPageNum.Text = CurrentPageIndex.ToString();            labFirstPage.Enabled = true;            labPreviousPage.Enabled = true;            labNextPage.Enabled = true;            labLastPage.Enabled = true;            labFirstPage.CssClass = "font-blue";            labPreviousPage.CssClass = "font-blue";            labNextPage.CssClass = "font-blue";            labLastPage.CssClass = "font-blue";            if (CurrentPageIndex == 1)            {                labFirstPage.Enabled = false;                labPreviousPage.Enabled = false;                labFirstPage.CssClass = "gray";                labPreviousPage.CssClass = "gray";            }            if (CurrentPageIndex == TotalNumberOfPages)            {                labNextPage.Enabled = false;                labLastPage.Enabled = false;                labNextPage.CssClass = "gray";                labLastPage.CssClass = "gray";            }            if (RecordCount == 0)            {                labFirstPage.Enabled = false;                labPreviousPage.Enabled = false;                labFirstPage.CssClass = "gray";                labPreviousPage.CssClass = "gray";                labNextPage.Enabled = false;                labLastPage.Enabled = false;                labNextPage.CssClass = "gray";                labLastPage.CssClass = "gray";            }        }

*    二零零一年微软发布了.NET Frameworrk 1.1正经版,个中ASP版本便是ASP.NET
1.1。*

当下页码、总共多少条记下使用ViewState记录状态信息,因为导航控件会挑起回发刷新。
分页后的数额加载,使用事件。

*    贰零零伍年微软发表.NET Framework 2.0行业内部版本,也正是ASP.NET 2.0。*”

事件的现实性完结放在使用分页控件的切切实实页面中,进行事件的注册。

 

测量检验分页控件的前台页面:

   
那是一段引自百度百科,介绍从asp发展到asp.net的记述。阅读这段记述你应该发掘到,asp.net是从asp1.0开始上扬来的,不过它不是直接从asp发展到asp.net的,首先是asp1.0,然后是asp2.0,然后是asp+,再然后改名叫asp.net(这里如果分别看就是asp
 、
 .net那是三个词,因为在asp的上进历程中另三个大的项目.net出现了,.net为啥出现,不在钻探范围,能够活动百度)。asp.net1.1手艺的web框架就是webform。

<div style="margin-bottom:10px;">            text:            <asp:TextBox ID="txtContent" runat="server"></asp:TextBox>            <asp:Button ID="btnQuery" runat="server" Text="查 询" OnClick="btnQuery_Click"/>        </div>        <div>            <asp:GridView ID="gvList" runat="server" Width="99%" AutoGenerateColumns="true"></asp:GridView>            <uc1:PagerControl runat="server" ID="Pager" />        </div>

    纵然本身没准备梳理陈诉.net的发出和发展,可是asp.net
webform的爆发却和.net平台十三分紧密。

测验分页控件的后台代码:

   
在asp发生的前四年,发生了别的一个老大闻名的动态网页本领,那便是PHP。这里推荐一下php的定义:

 private const string dtSourceViewStateKey = "dtSourceViewStateKey";        protected void Page_Load(object sender, EventArgs e)        {            if (!IsPostBack)            {                BindData(true);            }            Pager.OnPageChanged += OnPageChanged;        }        private void BindData(bool bindRecordCount)        {            DataTable dtSource = GetDataSource();                        var source = dtSource.AsEnumerable();            if (!string.IsNullOrEmpty(txtContent.Text.Trim            {                source = source.Where(w => w.Field<string>("text").Contains(txtContent.Text.Trim;            }            if (bindRecordCount)            {                Pager.RecordCount = source.Count();                Pager.CurrentPageIndex = 1;                Pager.DataBind();            }            gvList.DataSource = source                .Skip((Pager.CurrentPageIndex - 1) * Pager.PageSize)                .Take(Pager.PageSize)                .Select(r => new { id = r["id"].ToString(), text = r["text"].ToString                .ToList();            gvList.DataBind();        }        private void OnPageChanged()        {            BindData(false);        }        private DataTable InitDataTable()        {            DataTable dtSource = new DataTable();            DataColumn id = new DataColumn("id");            id.AutoIncrement = true;            id.AutoIncrementSeed = 1;            dtSource.Columns.Add;            dtSource.Columns.Add("text");            for (int i = 1; i <= 1000; i++)            {                DataRow dr = dtSource.NewRow();                dr["text"] = "内容" + i;                dtSource.Rows.Add;            }            return dtSource;        }        private DataTable GetDataSource()        {            if (ViewState[dtSourceViewStateKey] == null)            {                ViewState[dtSourceViewStateKey] = InitDataTable();            }            return ViewState[dtSourceViewStateKey] as DataTable;        }        protected void btnQuery_Click(object sender, EventArgs e)        {            BindData(true);        }

   “PHP(外文名:PHP: Hypertext
Preprocessor,中文名:“超文本预处理器”)是一种通用开源脚本语言语法吸收了C语言JavaPerl的特色,利于学习,使用广泛,重要适用于Web支出世界。PHP
独特的语法混合了CJavaPerl以及PHP自创的语法。它能够比CGI或者Perl越来越高速地实践动态网页。用PHP做出的动态页面与其他的编制程序语言相比,PHP是将程序嵌入到HTML行业内部通用标识语言下的叁个施用)文档中去推行,推行成效比完全成形HTML标记的CGI要高许多;PHP还足以实行编译后代码,编译能够高达加密优化代码运维,使代码运维越来越快。”

在Page_Load中注册翻页后的事件。

 

   
php的发生早于asp技艺,asp应该是接受有php手艺的修建观念的,之所以称为建造,是因为php的源点非常的低,并不曾被开展丰富的设计,它是从贰个小工具快速发展兴起的。这里还想提一下另外二个十分重要的动态网页技术,再次援用下百度宏观:

    “JSP全名称叫Java Server
Pages,中文名称叫java服务器页面,其平素是多少个简化的Servlet设计,它 [1]  是由Sun
Microsystems
合作社发起、多数市肆涉足球联合会合创造的一种动态网页技巧标准。JSP本事有一点类似ASP技能,它是在价值观的网页HTML(规范通用标志语言的子集)文件(\
.htm,*.html)中插入Java程序段(Scriptlet)和JSP标志(tag),从而产生JSP文件,后缀名称叫(*.jsp)。
用JSP开发的Web应用是跨平台的,既可以在Linux下运作,也能在另外操作系统上运维。*

它完毕了Html语法中的java扩张(以 <%,
%>形式)。JSP与Servlet同样,是在劳动器端施行的。常常再次回到给客商端的正是贰个HTML文本,因此顾客端只要有浏览器就会浏览。

*   
JSP技艺应用Java编制程序语言编写类XML的tags和scriptlets,来封装产生动态网页的处理逻辑。网页仍是可以够由此tags和scriptlets访谈存在于服务端的能源的应用逻辑。JSP将网页逻辑与网页设计的显得分离,帮忙可选取的依据组件的安顿,使基于Web的应用程序的成本变得十分的快和轻巧。
JSP(JavaServer
Pages)是一种动态页面本事,它的重要目标是将象征逻辑从Servlet中分离出来。*

Java Servlet是JSP的技艺基础,而且重型的Web应用程序的付出需求Java
Servlet和JSP合作工夫做到。JSP具有了Java本事的简便易用,完全的面向对象,具备平台无关性且安全可相信,主要面向因特网的全部特点。

 
 JSP才能比php、asp技艺产生的更晚,JSP技能未来被用来开拓超大型网址,可是而不是因为JSP本领本人非常精美,而是因为它发生于java之上。

 
 这些时期的asp、php、jsp等动态网页本事,皆有叁个共同点,正是您拜会url地址,明确是存在四个这么一个文本存在的。asp.net发生的技能基础是asp,那么asp.net的webform框架使用那同一思想就水到渠成了。webform的页面文件有两有的,后缀名是.aspx和.aspx.cs两有的组成。那一个是有别于asp的,asp页面文件唯有贰个,后缀名是.asp。从.asp到.aspx大家得以看来,aspx是在asp的前面加了x字母,联想微软的其他产品,.docx代替.doc、.xlsx代替.xls,多少能够窥见到微软对技艺晋级的命名思索。

   以上汇报,讲到了asp.net
 webform将页面文件拆分成了多个部分。那是十分大的八个改进,这种创新是为着缓和一些难点(不是八个,是一种类难题)。革新asp才能cs代码和html混在一起,暴露代码细节,asp页面不会被编写翻译成dll。同期也是有别的优势。

   从asp到asp.net,在webform框架中山高校量平放了ASP.NET
服务器控件,那是三个极大的退换,这种服务器控件分二种:

  • HTML 服务器控件 – 传统的 HTML 标签
  • Web 服务器控件 – 新的 ASP.NET 标签
  • Validation 服务器控件 – 用于输入验证

网络有一些人会说,那是为着消除开采asp页面会形成意大利共和国米糊的难点。笔者的精晓服务器控件的改变远不唯有于此,假若你创建二个纯服务器控件的页面(asp.net出现不久,很六个人就不指出那样干了,至于缘何,作者知道会扭转多量viewstate串,当然还大概有其余原因),然后对页面成分进行操作,随着使用的熟悉,你恐怕会发觉到webform的页面文件不是在html字符中间拼东西,或许说不是在一群服务器无法知道的东东中游,动态的变迁一些字符。它发展了非常多步,它把页面包车型地铁装有html便签加上标记,经过页面引擎管理,产生了足以被灵活操作的类,程序开垦职员可以自由操作这一个标签类,然后在贰个适用的时候,再将那个类逐条的“ToString()”成字符串,拼到页面上。发明服务器控件手艺,我的考虑根源可能是桌面应用程序开垦技能,从dos操作系统(命令行交互),到视窗操作系统(主若是鼠标点击、键盘按钮交互),开荒桌面应用程序,会大方用到控件技能,控件复用技巧能够大大提高开辟成效。为啥测度笔者的思量可财富于此,因为asp本事出现时,当时桌面应用程序开采依旧主流,小编或许感染在这种气氛内,把桌面应用程序开荒的统一打算思想调换至web先后的开销。这里要引出别的贰个东西,便是事件驱动,随意新建一个aspx页面,最重要的是事件管理方法,Page_Load。windows操作系统中大批量用到事件驱动,是基于“事件驱动模型”的。那么小编在webform中运用事件驱动,也大概借鉴了windows。

   
不管是服务器控件,依遗闻件驱动,那三种(只怕说是一种,因为控件和事件时期本就竞相关系)设计思想非常的大的影响了webform框架,开拓web应用程序的方法。服务器控件加事件驱动即使有益于异常快开采三个管制系统型web程序,不过并不符合web应用程序本人的运作思想,那一点被广大人商量,web程序因为不运转在桌面操作系统中,最初的时候它照旧无法相互,只是为了方便交流新闻,只用于展现消息。web程序本质运营规律是,通过浏览器向web服务器发送央求管理命令,有web托管程序接收央浼命令,实行操作,然后重返管理结果(结果也许是显得一篇小说,也许是报告您小说删除成功,或然是将你提高价格的消息内容举办了保留)。webform轻便令人误解它运营在操作系统可能浏览器中,全部代码实施在顾客端。尽管未来的浏览器真的能够将动态页面放在浏览器端实行,不过webform页面其实是有劳动器端的程序处理的。

   
假若要辩论和审视webform框架的规划观念,不得不比较其他一个框架观念,那就是mvc的框架(模型)的统一希图观念。mvc模型的评释,大概不是特意设计,而是对专门的学业的历历在目情考,然后抓住本质的产物。mvc模型是为了管理难题清晰明了,裁减耦合性。

   
由于不会php和jsp就不可能相比较那二种本事了,其实很想把它们也拉进来比较下,非常是jsp手艺,因为java的跨平台性,jsp设计时不会有太多windows的阴影,windows平时有种不想告诉你复杂的精神,所以小编给您打包二个简短的世界给你的感到,然后趁着你的中年人,这种前期的包装恐怕会是一个大的承受,或然说微软的事物有太多windows的影子,过于围绕windows了。

   
最后总计一下,假设您松开本人恐慌的神经,不给协和设置界限,随便联想,随便设计,不过分驰念全盘,你会觉获得web才能发展一些观念的承袭和变革。从轻巧的html纯文本浮现,文本浏览器的表明,背后的http公约0.9,再到图片显示,LiveScript的阐明(就是javascript),到CGI程序,再到Servlet拼接html本领,到php脚本,到asp动态页面本事,到jsp动态页面技艺,到webfrom框架,spring框架,mvc框架那个本领背后隐约有一条观念在串联起来。四个事物的声明不是突发性的,往往有一个不屑一提的前奏。

    

 

 

开卷本文请小心,假设你感觉混乱,那么就毫无阅读援引的片段,能够大致先只阅读别的内容。

本文并未开展认真的旁观和视察,有的地点大概是荒谬的,一些技巧的阐明先后也说不定并不确切。可是希望文中关心叁个本领的前行历史的思绪,能给你学习提供一些亮点。

 

 

 

 

 

 

 

 

留下评论

网站地图xml地图