|
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。
您需要 登录 才可以下载或查看,没有帐号?立即注册
x
asp可以轻松地实现对页面内容的动态控制,根据不同的浏览者,显示不同的页面内容。而浏览者一点觉察不出来,就像为他专门制作的页面一样。使用各种各样的组件,asp可以完成无比强大的功能。asp+|笔记 5).Pagelet控件
本人做控件最复杂的办法就是Pagelet控件,后缀为.aspc,用Register指令包括到WebForm中:
<%@ Register TagPrefix="Acme" TagName="Message" Src="pagelet1.aspc" %>
TagPrefix是Pagelet的称号空间界说,TagName是给Pagelet取的名字。Src属性是虚拟目次。
Pagelet的利用:
<Acme:Message runat="Server"/>
。表露Pagelet的办法,像一个类一样界说属性,例:
<script language="c#" runat="server">
public String Address{
get{
return TxtAddress.Value;
}
set{
TxtAddress.Value=value;
}
}
</script>
<input id="TxtAddress" runat="server">
。封装事务
略
可以看出,Pagelet可以代替include文件的感化。
。编程创立Pagelet对象
可以用法式生成Pagelet控件的实例,如:
Control cl=LoadControl("pagelet2.aspc");
((Pagelet2_aspc)cl).Category="business";
Page.Controls.Add(cl);
注重,由于LoadControl函数前往一个System.Web.UI.Control对象,因而需求外型。Pagelet
的类型为文件名,点号换成下划线。
6).数据帮定控件
asp+中,不但可以帮定到数据库,还可以帮定到复杂的属性纠合,乃至办法挪用的了局,如:
CustomerID: <%# custID %>
<asp:ListBox id="List1" datasource='<%# myArray %>' runat="server">
<%# (Customer.FirstName + Customer.LastName)%>
<%# GetBalance(CustID) %>
看起来跟asp中的<%=%>一样,然而ASP是用Response.Write来交换的,而ASP+则是在DataBind()
办法挪用后才帮定的。数据帮定控件和Page对象都有DataBind()办法。
注重,asp+是强类型的,所以:
<%# count.ToString() %>才对。
。DataBinder.Eval()
一个静态办法,由ASP+撑持,答应后帮定的数据帮定表达式,并且还可选地转化为串,可以
用于模板。如不必Eval,则像:
<%# String.Format("{0:c}",((DataRowView)Container.DataItem)["SomeInteger"]) %>
可以用Eval:
<%# DataBinder.Eval(Container.DataItem,"someinteger","{0:c}") %>
7).办事器方数据会见
。毗连、号令和数据集(DataSets)
NGWS供应了一系列受管数据会见API,引入称号空间:
<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SQL" %>
a).生成SQLConnection
b).机关SQLDatasetCommand
c).FillDataSet
假如是拔出等操作,则用SQLCommand交换SQLDataSetCommand.
记住:一直在用完毗连后封闭毗连!不然要比及页面被释放时才会被渣滓收受接管机制释放资本。
。帮定命据到DataGrid,例:
....
DataSet ds = new DataSet();
myCommand.FillDataSet(ds,"Authors");
MyDataGrid.DataSource = ds.Tables["Authors"].DefaultView;
MyDataGrid.DataBind();
。参数化查询
SQLDataSetCommand撑持参数,"@"作为参数前缀,例:
myCommand.SelectCommand.Parameters.Add(new SQLParameter("@state",SQLDataType.VarChar,2));
myCommand.SelectCommand.Parameters["@state"].Value=newValue;
注重,假如DataGrid要在客户与办事器间轮转的话,必定要把MaintainState属性设置为false,
不然,功能遭到影响,如:
<asp:DataGrid id="myDataGrid" runat="server"
MaintainState="false"/>
。拔出数据
应该包管不为null,可使用try/catch块。
例:
String insertcmd = "insert into Authors values(@id,@lname)"
SQLCommand myc = new SQLCommand(insertcmd,myConn);
myc.Parameters["@id"].Value=cu_id.Value;
myc.Parameters["@lname"].Value=au_lname.Value;
myc.ActiveConnection.Open();
try{
myc.Execute();
}catch(SQLException e){
if (e.Number==2627)
......//主键反复
}
myc.ActiveConnection.Close();
。更新纪录
DataGrid供应了一些内涵撑持,有一个整型属性,EditItemIndex,暗示哪一行可以编纂,一但设置,
该行的文本输出框显示,而不是却省的静态文本,如为-1则暗示没有行可以编纂。
DataGrid可以包括一个控件,EditCommandColumn,它将为DataGrid激发三个事务,EditCommand,
UpdateCommand,和CancelCommand。EditCommandColumn在属性顶用Columns界说,如:
<ASP:DataGrid id="MyDataGrid" runat="server"
......
onEditCommand="MyDataGrid_Edit"
onCancelCommand="MyDataGrid_Cancel"
onUpdateCommand="MyDataGrid_Updat</p>[1] [2] 下一页
缺点:安全性不是太差了,还行,只要你充分利用系统自带的工具;唯一缺点就是执行效率慢,如何进行网站优化以后,效果会比较好。 |
|