最近在网上看到有些人就在问什么是三成层结构?呵呵,其实了这个问题只要是有过实际开发经验的人都会知道。
先写一个简单的例子来说明问题吧~!
在VS2005里面 新建一个网站 然后在App_Code文件夹中添加一个类 于下
using System;
using System.Data;
using System.Configuration;
using System.Web;
using System.Web.Security;
using System.Web.UI;
using System.Web.UI.WebControls;
using System.Web.UI.WebControls.WebParts;
using System.Web.UI.HtmlControls;
using System.Data.SqlClient;
using System.Collections.Generic; //引用泛型
//数据访问层
public class cls
{
public DataView getData()
{
using(SqlConnection conn = new SqlConnection("server=.;uid=sa;pwd=sa;database=northwind"))
{
conn.Open();
SqlDataAdapter sa = new SqlDataAdapter("select UnitPrice from [Order Details]", conn);
DataTable dt = new DataTable();
sa.Fill(dt);
return dt.DefaultView;
}
}
}
//数据实体
public class orders
{
double price;
public double disprice
{
get { return price; }
set { price = value; }
}
}
//业务逻辑层
public class bs
{
public List<orders> getprice(double getprice) //定义一个泛型的方法
{
List<orders> list = new List<orders>();
cls cs = new cls();
DataView dv = cs.getData();
foreach(DataRowView d in dv)
{
orders ord = new orders();
ord.disprice = double.Parse(d["UnitPrice"].ToString()) * getprice;
list.Add(ord);
}
return list;
}
}
这个类的作用就是返回价格 然后呈现在GridView中 在业务逻辑层中写了一个泛型的方法,这样显得更灵活。
然后再界面层写于下
//UI层
protected void Button1_Click(object sender, EventArgs e)
{
bs b = new bs();
GridView1.DataSource = b.getprice(double.Parse(TextBox1.Text));
GridView1.DataBind();
}