您现在的位置: 军旅同心-旅游自驾-军旅文学 >> 读书赏析 >> 学习园地 >> 电脑网络 >> 技术文章 >> 正文
asp.net高级教程(二)- 转换编程思维
作者:采集员 文章来源:来源于网络 点击数: 更新时间:2005-9-10 12:36:53
上次的内容说过asp.net和asp的最大区别在于编程思维的转换,那么我们现在就来看看如何转换编程思想。以前的web编程从cgi(perl)到asp,php,jsp的编程过程都是这样:美工人员给出页面原型,编程人员照页面填空,最后堆起来算完,下次如果原型变动,那么就再修改程序,这样业务逻辑和html页面混在一起,可以说是事倍功半。那么,现在有了asp.net,我们应该怎么做呢?

    让我们找个实际的例子,就拿论坛来说吧,先从顶至下看看它的业务逻辑。我们可以把一个论坛视做一个对象,它有自己的属性和方法,常见的属性有名称、贴子数、用户数、版面数等等,这样的话,我们就可以这样来构造论坛对象:

namespace MyOwnClass
{
    using System;
    using System.Data.SQL ;
    using System.Data ;
    
    ////////////////////////////////////////////////////////////////////
    //
    // Class Name :       BBS
    //
    // Description:       论坛类,构造一个论坛对象
    //
    // date:              2000/02/03
    //
    /// ////////////////////////////////////////////////////////////////
    public class BBS
    {
        //私有变量
        private string m_strTitle ;        //bbs名称
        private int m_intForumCount ;        //版面数
        private int m_intTopicCount ;        //贴子数
        private int m_intUserCount ;        //注册用户数
        
        //属性
        public string Title
        {
            get
            {
                return m_strTitle ;
            }
        }

        public int ForumCount
        {
            get
            {
                return m_intForumCount ;
            }
        }

        public int TopicCount
        {
            get
            {
                return m_intTopicCount ;
            }
        }

        public int UserCount
        {
            get
            {
                return m_intUserCount ;
            }
        }

        //构造函数
        public BBS(string a_strTitle)
        {
            //
            // TODO: Add Constructor Logic here
            //
            m_strTitle = a_strTitle ;

            //读取数据库
            MyConnection myConn = new MyConnection() ;
            SQLCommand myCommand = new SQLCommand() ;
            myCommand.ActiveConnection = myConn ;
            myCommand.CommandText = "up_GetBBSInfo" ;    //调用存储过程
            myCommand.CommandType = CommandType.StoredProcedure ;

            try
            {
                myConn.Open() ;
                SQLDataReader myReader ;
                myCommand.Execute(out myReader) ;
                if (myReader.Read())
                {
                    m_intForumCount = (int)myReader["ForumCount"] ;
                    m_intTopicCount = (int)myReader["TopicCount"] ;
                    m_intUserCount  = (int)myReader["UserCount"] ;
                }
                else
                {
                    throw(new Exception("表或存储过程不存在")) ;
                }

                //清场
                myReader.Close();
                myConn.Close() ;
            }
            catch(SQLException e)
            {
                throw(new Exception("数据库出错:" + e.Message)) ;
            }

        }
    }
}

    这个bbs类很简单,有四个私有变量,对应四个只读属性,方法只有一个带参数的构造函数,作用是从数据库中读取相应的数据,填充四个私有变量。类构造好了,让我们看看如何使用,在需要显示论坛这些属性的页面文件里(.aspx)里,构造四个Label,象这样:
     <table width=140 cellpadding=4 cellspacing=1 border=0>
       <tr>
          <td class=cn>
              <font color=white>注册用户数:</font>
          </td>
          <td>    
              <asp:label id="lblUserCount" runat=Server class=cn></asp:label>
          </td>
       </tr>
       <tr>
          <td class=cn>
              <font color=white>贴子总数:</font>
          </td>
          <td>    
              <asp:label id="lblTopicCount" runat=Server class=cn></asp:label>
          </td>
       </tr>
       <tr>
      

[1] [2] 下一页


更多
免责声明:作品版权归所属媒体与作者所有!!本站刊载此文不代表同意其说法或描述,仅为提供更多信息。如果您认为我们侵犯了您的版权,请告知!本站立即删除。有异议请联系我们。
文章录入:烟灰缸    责任编辑:烟灰缸 
网友评论:(只显示最新10条。评论内容只代表网友观点,与本站立场无关!)
| 设为首页 | 加入收藏 | 联系站长 | 友情链接 | 网站地图 | 版权申明 | 网站公告 | 管理登录 |