ASP+ 学习笔记 2

<a href='http://www.biancheng88.cn/html/2008-11/ASP-65587948.html'>ASP+ 学习笔记 2</a><br><br>
                  5).Pagelet控件<br>
    自己做控件最简单的方法就是Pagelet控件,后缀为.aspc,用Register指令包含到WebForm中:<br>
    <%@ Register TagPrefix="Acme" TagName="Message" Src="pagelet1.aspc" %><br>
    TagPrefix是Pagelet的名称空间定义,TagName是给Pagelet取的名字。Src属性是虚拟目录。<br>
    Pagelet的使用:<br>
    <Acme:Message runat="Server"/><br>
    。暴露Pagelet的方法,像一个类一样定义属性,例:<br>
    <script language="c#" runat="server"><br>
    public String Address{<br>
        get{<br>
            return TxtAddress.Value;<br>
        }<br>
        set{<br>
            TxtAddress.Value=value;<br>
        }<br>
    }<br>
    </script><br>
    <input id="TxtAddress" runat="server"><br>
    。封装事件<br>
    略<br>
    可以看出,Pagelet可以取代include文件的作用。<br>
    。编程创建Pagelet对象<br>
    可以用程序生成Pagelet控件的实例,如:<br>
    Control cl=LoadControl("pagelet2.aspc");<br>
    ((Pagelet2_aspc)cl).Category="business";<br>
    Page.Controls.Add(cl);<br>
    注意,因为LoadControl函数返回一个System.Web.UI.Control对象,因此需要造型。Pagelet<br>
的类型为文件名,点号换成下划线。<br>
<br>
6).数据帮定控件<br>
    asp+中,不仅可以帮定到数据库,还可以帮定到简单的属性集合,甚至方法调用的结果,如:<br>
    CustomerID: <%# custID %><br>
    ' runat="server"><br>
    <%# (Customer.FirstName + Customer.LastName)%><br>
    <%# GetBalance(CustID) %><br>
    看起来跟asp中的<%=%>一样,但是<a href="http://www.biancheng88.cn/html/special/2008-11/ASP/" title="ASP" target=_blank><B>ASP</B></a>是用Response.Write来替换的,而ASP+则是在DataBind()<br>
方法调用后才帮定的。数据帮定控件和Page对象都有DataBind()方法。<br>
    注意,asp+是强类型的,所以:<br>
        <%# count.ToString() %>才对。<br>
    。DataBinder.Eval()<br>
    一个静态方法,由ASP+支持,允许后帮定的数据帮定表达式,而且还可选地转化为串,可以<br>
用于模板。如不用Eval,则像:<br>
    <%# String.Format("{0:c}",((DataRowView)Container.DataItem)["SomeInteger"]) %><br>
    可以用Eval:<br>
    <%# DataBinder.Eval(Container.DataItem,"someinteger","{0:c}") %><br>
    <br>
7).服务器方数据访问<br>
    。连接、命令和数据集(DataSets)<br>
    NGWS提供了一系列受管数据访问API,引入名称空间:<br>
    <%@ Import Namespace="System.Data" %><br>
    <%@ Import Namespace="System.Data.SQL" %><br>
    a).生成SQLConnection<br>
    b).构造SQLDatasetCommand<br>
    c).FillDataSet<br>
    如果是插入等操作,则用SQLCommand替换SQLDataSetCommand.<br>
    记住:始终在用完连接后关闭连接!否则要等到页面被释放时才会被垃圾回收机制释放资源。<br>
    。帮定数据到DataGrid,例:<br>
        ....<br>
        DataSet ds = new DataSet();<br>
        myCommand.FillDataSet(ds,"Authors");<br>
        MyDataGrid.DataSource = ds.Tables["Authors"].DefaultView;<br>
        MyDataGrid.DataBind();<br>
        <br>
    。参数化查询<br>
        SQLDataSetCommand支持参数,"@"作为参数前缀,例:<br>
        <br>
        myCommand.SelectCommand.Parameters.Add(new SQLParameter("@state",SQLDataType.VarChar,2));<br>
        myCommand.SelectCommand.Parameters["@state"].Value=newValue;<br>
        <br>
    注意,如果DataGrid要在客户与服务器间轮转的话,一定要把MaintainState属性设置为false,<br>
否则,性能受到影响,如:<br>
   
    MaintainState="false"/><br>
    <br>
    。插入数据<br>
    应当保证不为null,可以使用try/catch块。<br>
    例:<br>
    String insertcmd = "insert into Authors values(@id,@lname)"<br>
    SQLCommand myc = new SQLCommand(insertcmd,myConn);<br>
    myc.Parameters["@id"].Value=cu_id.Value;<br>
    myc.Parameters["@lname"].Value=au_lname.Value;<br>
    myc.ActiveConnection.Open();<br>
    try{<br>
        myc.Execute();<br>
    }catch(SQLException e){<br>
        if (e.Number==2627)<br>
        ....http://www.zhujiangroad.com//主键重复<br>
        }<br>
    myc.ActiveConnection.Close();<br>
    <br>
    。更新记录<br>
    DataGrid提供了一些内在支持,有一个整型属性,EditItemIndex,表示哪一行可以编辑,一但设置,<br>
该行的文本输入框显示,而不是却省的静态文本,如为-1则表示没有行可以编辑。<br>
    DataGrid可以包含一个控件,EditCommandColumn,它将为DataGrid引发三个事件,EditCommand,<br>
UpdateCommand,和CancelCommand。EditCommandColumn在属性中用Columns定义,如:<br>
    <ASP:DataGrid id="MyDataGrid" runat="server"<br>
    ......<br>
    onEditCommand="MyDataGrid_Edit"<br>
    onCancelCommand="MyDataGrid_Cancel"<br>
    onUpdateCommand="MyDataGrid_Update"<br>
    DataKeyField="au_id"<br>
    ><br>
    <property name="Columns"><br>
        <br>
    </property><br>
    </ASP:DataGrid><br>
    <br>
    Edit事件中参数DataGridCommandEventArgs参数包含了用户选择的行,然后我们可以重新帮定,<br>
以刷新显示。例:<br>
    public void MyDataGrid_Edit(Object sender,DataGridCommandEventArgs E){<br>
        MyDataGrid.EditItemIndex = (int)E.Item.ItemIndex;<br>
        BindGrid();//调用另外的函数实现重新帮定<br>
    }<br>
    <br>
    在Cancel事件中,我们只需要把EditItemIndex设为-1就可以了。<br>
    在Update事件中,我们需要更新数据。要知道当前行的主键值,这可以用刚才设的DataKeyField<br>
来获得,我们可以获得行的主键值,如:<br>
    myCommand.Parameters["@id"].Value=MyDataGrid.DataKeys[(int)E.Item.ItemIndex];<br>
    最后将EditItemIndex设为-1。<br>
    为了防止用户修改主键,可以单独定义一行中各列的表现,将其改为只读,如:<br>
    <<a href="http://www.biancheng88.cn/html/special/2008-11/ASP/" title="ASP" target=_blank><B>ASP</B></a>:DataGrid id="MyDataGrid" runat="server"<br>
    ......<br>
    DataKeyField="au_id"<br>
    AutoGenerateColumns="false"<br>
    ><br>
    <property name="Columns"><br>
        <br>
        <br>
        <br>
        ......<br>
    </property><br>
    </<a href="http://www.biancheng88.cn/html/special/2008-11/ASP/" title="ASP" target=_blank><B>ASP</B></a>:DataGrid><br>
    <br>
    。删除记录<br>
    加一个ButtonColumn控件,Command设为"Delete",将引发DeleteCommand事件。<br>
    <br>
    。排序<br>
    当用户点一列的Header时,如果DataGrid的AllowSorting属性为True,则一个OnSortCommand<br>
事件产生,参数DataGridSortCommandEventArgs的SortField传回来的是哪一个列被选中,如:<br>
    protected void MyDataGrid_Sort(Object src,DataGridSortCommandEventArgs E){<br>
        DataView source=ds.Tables["Authors"].DefautlView;<br>
        Source.Sort=E.SortField;<br>
        MyDataGrid.DataBind();<br>
    }<br>
    <br>
    。表间关系<br>
    用一列做个连接,跳转到另一页去查看对应的详细资料,用控件HyperLinkColumn,如:<br>
    <property name="Columns"><br>
       
        DataNavigateUrlField="au_id"<br>
        DataNavigateUrlFormatString="a.aspx?id={0}"<br>
        Text="详细情况"<br>
        /><br>
    </property><br>
    <br>
    。访问基于xml的数据<br>
    DataSet有一个方法叫ReadXml,用FileStream作为参数,xml文件的格式为:<br>
    <DocumentElement><br>
        <TableName><br>
            <ColumnName1>Comumn Value</ColunName1><br>
            ......<br>
        </TableName><br>
    </DocumentElement><br>
    <br>
    每一个<TableName>段代表一行数据。<br>
    例:<br>
    DataSet ds = new DataSet();<br>
    FileStream fs = new FileStream(Server.Mappath("a.xml"),FileMode.Open,FileAccess.Read);<br>
    StreamReader reader = new StreamReader(fs);<br>
    ds.ReadXml(reader);<br>
    DataView source = new DataView(ds.Tables[0]);<br>
    MySpan.InnerHtml = source.Table.TableName;<br>
    MyDataGrid.DataSource = source;<br>
    MyDataGrid.DataBind();<br>
    还可以分别调用ReadXmlSchema和ReadXmlData分开读取模式和数据。   <br>

                 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值