荔园在线

荔园之美,在春之萌芽,在夏之绽放,在秋之收获,在冬之沉淀

[回到开始] [上一篇][下一篇]


发信人: Benison (感冒了,555~~~~), 信区: Homepage
标  题: ASP+ 学习笔记 2
发信站: BBS 荔园晨风站 (Wed Oct 18 13:12:51 2000), 转信


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事件


    。排序
    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分开读取模式和数据。




--
 Benison给你深深的祝福! 深圳大学排球俱乐部就在http://szuvc.home.chinaren.net

欢迎到深大排协主页:
      http://szuvc.home.chinaren.net

※ 来源:·BBS 荔园晨风站 bbs.szu.edu.cn·[FROM: 192.168.39.38]


[回到开始] [上一篇][下一篇]

荔园在线首页 友情链接:深圳大学 深大招生 荔园晨风BBS S-Term软件 网络书店