小菜鸟求教,c#gridview添加数据问题

小菜鸟求教,c#gridview添加数据问题,第1张

对GridView增加空白行

存在数据的时候,就需要用到DataTable

1

2

3

4

5

6

7

8

9

10

11

DataTable dt = this.GridView1.DataSource as DataTable

DataRow dr = dt.NewRow()

//也就是说存在数据源时候需要是同DataTable获取当前的绑定数据,然后DataTable新增一行空值的行再次绑定就OK

//不存在数据源也可以这么做

//或者这个

protected void Button1_Click(object sender, EventArgs e)

{

this.SqlDataSource1.Insert()

this.GridView1.DataBind()

}

请问,这样做的目的是什么,有什么意义?

就算一行一行的添加数据,那也是需要绑定数据源的,要实现逐行添加数据不是不可以实现,只是真的没明白为啥要这样做。。。

比如下面代码:

//定义数据源 table

public static DataTable Cpdt

//页面加载

protected void Page_Load(object sender, EventArgs e)

{

if (!IsPostBack)

{

Cpdt = new DataTable()

Createbt()

GridView1.DataSource = Cpdt

GridView1.DataBind()

}

}

//根据自己需求创建表

void Createbt()

{

DataColumn mycol = new DataColumn()

Cpdt.Columns.Add(new DataColumn("CPID", typeof(Int32)))

Cpdt.Columns.Add(new DataColumn("CPNAME", typeof(String)))

Cpdt.Columns.Add(new DataColumn("CPDJ", typeof(Single)))

Cpdt.Columns.Add(new DataColumn("SL", typeof(Int32)))

Cpdt.Columns.Add(new DataColumn("CPSUM", typeof(Double)))

Cpdt.AcceptChanges()

Cpdt.PrimaryKey = new DataColumn[] { Cpdt.Columns[0] }

Cpdt.AcceptChanges()

}

//比如点击button的时候添加一条数据

protected void Button1_Click(object sender, EventArgs e)

{

DataRow myrow = Cpdt.NewRow()

if (Cpdt.Rows.Count==0)

{

myrow[0] = 1

}

else

{

myrow[0] = int.Parse(Cpdt.Rows[Cpdt.Rows.Count-1][0].ToString()) + 1

}

myrow[1] = 2

myrow[2] = 3

myrow[3] = 4

Cpdt.Rows.Add(myrow)

var mm = Cpdt.AsEnumerable().Sum(p =>Convert.ToDouble(p["SL"]))

//Label3.Text = mm.ToString()

Cpdt.AcceptChanges()

GridView1.DataSource = Cpdt

GridView1.DataBind()

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/bake/11400849.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-15
下一篇 2023-05-15

发表评论

登录后才能评论

评论列表(0条)

保存