[英]DataGridView generating rows without data
我已经在这里和Google进行了搜索,但仍然找不到答案。 我正在使用Amazon的API,并且正在制作一个简单的Windows窗体来尝试在DataGridView中显示数据。 GridView会为我得到的10个结果生成10行,但没有用实际数据填充行。 他们只是空白。
下面的代码是一个返回DataTable的方法(GetResults)。 我没有显示所有内容,因为上面有很多代码来获取数据。
DataTable dt = new DataTable();
dt.Columns.Add("ASIN", typeof(string));
dt.Columns.Add("Title", typeof(string));
// write out the results
foreach (var item in response.Items[0].Item)
{
Product product = new Product(item.ASIN, item.ItemAttributes.Title);
Console.WriteLine(product.ASIN);
var dr = dt.NewRow();
dr["ASIN"] = product.ASIN;
dr["Title"] = product.Title;
dt.Rows.Add();
}
return dt;
}
private void btnSearch_Click(object sender, EventArgs e)
{
dgvProducts.AutoGenerateColumns = false;
dgvProducts.DataSource = GetReults();
}
我知道它正在获取信息,因为我正在将其写入控制台并正确显示。
我也有这个产品的基本课程:
public class Product
{
private string asin;
private string title;
public Product() { }
public Product(string newAsin, string newTitle)
{
this.asin = newAsin;
this.title = newTitle;
}
public string ASIN
{
get { return asin; }
set { asin = value; }
}
public string Title
{
get { return title; }
set { title = value; }
}
我尝试设置AutoGenerateColumns = false并自己设置列数据绑定,但这也没有做任何事情。
您正在向表中添加一个空行,而不是添加新创建的行。
Change
dt.Rows.Add();
To
dt.Rows.Add(dr);
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.