WEB开发网
开发学院WEB开发ASP ASP+学习笔记(二) 阅读

ASP+学习笔记(二)

 2000-10-18 09:50:18 来源:WEB开发网   
核心提示:5).Pagelet控件自己做控件最简单的方法就是Pagelet控件,后缀为.aspc,ASP+学习笔记(二),用Register指令包含到WebForm中:<%@ Register TagPRefix="Acme" TagName="Message" Src="
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_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分开读取模式和数据。


Tags:ASP 学习 笔记

编辑录入:爽爽 [复制链接] [打 印]
赞助商链接