這個源碼是我根據網上一個vb.net編輯xml文件的原理用c#重寫的。除重用xml文件外.
並未重用任何代碼!.
這小段代碼,可對xml文件的記錄進行刪除,修改,或增加新記錄。
利用了datagrid控件的sortcommand事件對xml裡的記錄進行排序。
email:ouyang76.263.net
------------------------------------------
<%@page language="c#" Trace="true"%>
<%@import namespace="System.Data"%>
<%@import namespace="System.IO"%>
<script language="c#" runat="server">
string xmlfile="books2.xml",xpath;
void page_load(Object obj,EventArgs e)
{
xpath=Server.MapPath(xmlfile);
if(!Page.IsPostBack)
{
Dataload("isbn");
}
}
void Dataload(string psort)
{
DataSet ds=new DataSet();
FileStream fs=new FileStream(xpath,FileMode.Open);
ds.ReadXml(fs);
if(ds.Tables.Count==0)
{
Response.Write("xml文件內無記錄!!!!");
fs.Close();
Response.End();
}
Trace.Warn("表記錄數",Convert.ToString(ds.Tables[0].Rows.Count));
DataRow dr=ds.Tables[0].NewRow();//新建一行
dr["ISBN"] = " Add ISBN";
ds.Tables[0].Rows.InsertAt(dr,0);//插入到第0行位置
Trace.Warn("表數目",Convert.ToString(ds.Tables.Count));//以紅字顯示調試信息
//grid1.DataSource=ds.Tables[0].DefaultView;
//grid1.DataBind();
DataView dv=new DataView(ds.Tables[0]);
Trace.Warn("字串長度:"+psort,Convert.ToString(psort.Length));//排序字符串的長度
if(psort.Length>0)
dv.Sort=psort;
grid1.DataSource=dv;
grid1.DataBind();
fs.Close();
}
void grid_sort(Object obj,DataGridSortCommandEventArgs e)
{
if(grid1.EditItemIndex==-1)
Dataload(e.SortExpression);
else
Response.Write("正在編輯暫不能排序!!");
}
void grid_edit(Object obj,DataGridCommandEventArgs e)
{
grid1.EditItemIndex=(int)e.Item.ItemIndex;
show_del("hide");
Dataload("");
}
void grid_cancel(Object obj,DataGridCommandEventArgs e)
{
grid1.EditItemIndex=-1;
show_del("show");
Dataload("");
}
void grid_update(Object obj,DataGridCommandEventArgs e)
{
int numcell=e.Item.Cells.Count;//單元格數目(e.Item是當前發生事件的表格行)
int currentrow=e.Item.DataSetIndex;
//int curr2=e.Item.ItemIndex;//與上句等價,可以不帶(int)
Trace.Warn("當前更新行號 = ",Convert.ToString(currentrow));
//Trace.Warn("2當前更新行號 = ",Convert.ToString(curr2));
DataSet ds=new DataSet();
ds.ReadXml(xpath);//將xml模式和數據讀取到dataSet;
DataRow dr;//表示DataTable中的一行信息.
if(currentrow==0)
dr=ds.Tables[0].NewRow();
else
dr=ds.Tables[0].Rows[e.Item.DataSetIndex - 1];
string[] str={"isbn", "author", "title", "category", "comments"};
int j=-1;
for(int i=2;i<numcell;i++)//跳過1和2column
{
j=j+1;
string ctext;
ctext=((TextBox)e.Item.Cells[i].Controls[0]).Text;
dr[str[j]] = ctext;
Trace.Warn(Convert.ToString(i)+str[j]+":每一行的文本",ctext);
}
if(currentrow==0)
{
Response.Write("加入新記錄!!");
ds.Tables[0].Rows.InsertAt(dr,0);
}
ds.WriteXml(xpath);//將表示dataset的xml寫入到xml文件中,包括數據和模式.
grid1.EditItemIndex = -1;//無此句仍在編輯界面
show_del("show");
Dataload("");
}
void show_del(string state)
{
string tmp=state;
switch(tmp)
{
case "show":
grid1.Columns[0].Visible = true;
break;
case "hide":
grid1.Columns[0].Visible = false;
break;
default:
grid1.Columns[0].Visible = true;
break;//也要帶break
}
}
void initialize(Object obj,DataGridItemEventArgs e)//注意參數與其它函數不同
{
//e.Item.Cells[0].Text="aaaaa";//
if(e.Item.ItemIndex==0)//如果是第一行
{
LinkButton a0=new LinkButton();
a0=(LinkButton)e.Item.Cells[0].Controls[0];
LinkButton a1=new LinkButton();
a1=(LinkButton)e.Item.Cells[1].Controls[0];//在grid內建一個linkbutton控件
if(a0.Text=="刪 除")
a0.Text="";
if(a1.Text=="編 輯")
a1.Text="[AddNew]";
}
}
void grid_del(Object obj,DataGridCommandEventArgs e)
{
Response.Write("XX");
Trace.Warn("正要刪除",Convert.ToString(e.Item.ItemIndex));//控件中的行數