l留言簿是网站上很常见的一个功能。一个访问者可以通过这个留言簿留下姓名,EMAIL,消息标题及内容。内容显示用ASPxNewscontrol控件。类似界面如下:
步骤:
1.界面设计
2.定义一个持久类
3.XPO与数据库建立连接
4.把Comment 绑定到XpoDataSource 控件
5.创建XPO session
6.绑定数据源到ASPxNewsControl
7.实现保存内容
具体实现:
1.界面设计:
先拖拽 一个XpoDataSource控件用于存放数据和从数据库中查询数据。在拖拽一个ASPxNewsControl用于显示数据,在拖拽一个ASPxRoundPanel来做个编辑留言的区域,再分别拖拽三个ASPxLabel和ASPxTestBox和ASPxMemo 和一个ASPxbutton,并修改下ID属性。
2.定义持久类:
先创建一个名为:Comment的持久对象的类;代码如下:
public class Comment : XPObject
{
public DateTime Date;
public string Text;
public string Title;
public string Email;
public Comment()
: base()
{
}
public Comment(Session session)
: base(session)
{
// This constructor is used when an object is loaded from a persistent storage.
// Do not place any code here.
}
public Comment(Session session, DateTime date, string text, string title, string email, string visitorName)
: base(session)
{
this.Date = date;
this.Text = text + "[" + visitorName + "," + email + "]";
this.Title = title;
}
public override void AfterConstruction()
{
base.AfterConstruction();
// Place here your initialization code.
}
}
3.XPO与数据库建立连接。
在Application_Start事件里写入一下代码:
protected void Application_Start(object sender, EventArgs e)
{
string conn = DevExpress.Xpo.DB.AccessConnectionProvider.GetConnectionString(Server.MapPath("~\\App_Data\\Comments.mdb"));
DevExpress.Xpo.Metadata.XPDictionary dict = new DevExpress.Xpo.Metadata.ReflectionDictionary();
dict.GetDataStoreSchema(typeof(Comment).Assembly);
DevExpress.Xpo.XpoDefault.Session = null;
DevExpress.Xpo.DB.IDataStore store = DevExpress.Xpo.XpoDefault.GetConnectionProvider(conn, DevExpress.Xpo.DB.AutoCreateOption.SchemaAlreadyExists);
DevExpress.Xpo.XpoDefault.DataLayer = new DevExpress.Xpo.ThreadSafeDataLayer(dict, store);
}
4.把Comment绑定到XPODataSource控件上
5.创建Session
在PageInit事件里填写如下代码:
protected void Page_Init(object sender, EventArgs e)
{
session1 = new Session();
XpoDataSource1.Session = session1;
}
6.实现保存
在buttonclick事件里填写如下代码:
Comment newComment = new Comment(session1, DateTime.Today, ASPxMmContent.Text, ASPxTbTitle.Text, ASPxTbEmail.Text, ASPxTbName.Text);
newComment.Save();
ASPxNewsControl1.DataBind();
OK,启动调试:
界面出来了,
总结:
这一节我们实现了一个简单的留言板的功能。巩固了ASP.NET应用程序使用XPO操作数据库的一般步骤。练习了ASPxNewsControl和ASPxRoundPanel的使用。