|
源代码网推荐
5).Pagelet控件 自己做控件最简单的方法就是Pagelet控件,后缀为.aspc,用Register指令包含到WebForm中: <%@ Register TagPrefix="Acme" TagName="Message" Src="http://edu.cnzz.cn/NewsInfo/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_Update" DataKeyField="au_id" > <property name="Columns"> <asp:EditCommandColumns EditText="编辑" CancelText="取消" UpdateText="更新"/> </property> </ASP:DataGrid>
Edit事件中参数DataGridCommandEventArgs参数包含了用户选择的行,然后我们可以重新帮定, 以刷新显示。例: public void MyDataGrid_Edit(Object sender,DataGridCommandEventArgs E){ MyDataGrid.EditItemIndex = (int)E.Item.ItemIndex; BindGrid();//调用另外的函数实现重新帮定 }
在Cancel事件中,我们只需要把EditItemIndex设为-1就可以了。 在Update事件中,我们需要更新数据。要知道当前行的主键值,这可以用刚才设的DataKeyField 来获得,我们可以获得行的主键值,如: myCommand.Parameters["@id"].Value=MyDataGrid.DataKeys[(int)E.Item.ItemIndex]; 最后将EditItemIndex设为-1。 为了防止用户修改主键,可以单独定义一行中各列的表现,将其改为只读,如: <ASP:DataGrid id="MyDataGrid" runat="server" ...... DataKeyField="au_id" AutoGenerateColumns="false" > <property name="Columns"> <asp:EditCommandColumn EditText="编辑" CancleText="取消" UpdateText="更新"/> <asp:BoundColumn HeaderText="au_id" SortField="au_id" ReadOnly="True" DataField="au_id"/> <asp:BoundColumn HeaderText="电话" SortField="phone" DataField="phone"/> ...... </property> </ASP:DataGrid>
。删除记录 加一个ButtonColumn控件,Command设为"Delete",将引发DeleteCommand事件。
。排序 当用户点一列的Header时,如果DataGrid的AllowSorting属性为True,则一个OnSortCommand 事件产生,参数DataGridSortCommandEventArgs的SortField传回来的是哪一个列被选中,如: protected void MyDataGrid_Sort(Object src,DataGridSortCommandEventArgs E){ DataView source=ds.Tables["Authors"].DefautlView; Source.Sort=E.SortField; MyDataGrid.DataBind(); }
。表间关系 用一列做个连接,跳转到另一页去查看对应的详细资料,用控件HyperLinkColumn,如: <property name="Columns"> <asp:HyperLinkColunn DataNavigateUrlField="au_id" DataNavigateUrlFormatString="a.aspx?id={0}" Text="详细情况" /> </property>
。访问基于xml的数据 DataSet有一个方法叫ReadXml,用FileStream作为参数,xml文件的格式为: <DocumentElement> <TableName> <ColumnName1>Comumn Value</ColunName1> ...... </TableName> </DocumentElement>
每一个<TableName>段代表一行数据。 例: DataSet ds = new DataSet(); FileStream fs = new FileStream(Server.Mappath("a.xml"),FileMode.Open,FileAccess.Read); StreamReader reader = new StreamReader(fs); ds.ReadXml(reader); DataView source = new DataView(ds.Tables[0]); MySpan.InnerHtml = source.Table.TableName; MyDataGrid.DataSource = source; MyDataGrid.DataBind(); 还可以分别调用ReadXmlSchema和ReadXmlData分开读取模式和数据。
源代码网供稿. |