请问DataList能插入一条数据行吗?

badcody 2003-10-18 02:40:47
我声明了一个DataList,根据绑定的数据表,他生成了几行记录。我能在任意位置添加一条数据行吗?

或者说,我想插入一条ItemTemplate,可以吗?
...全文
180 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
saucer 2003-10-19
  • 打赏
  • 举报
回复
>>>那么,在DataGrid中,也能动态生成一行并加入吗?

yes, see an example at
http://www.xmlforasp.net/codeSection.aspx?csID=93
badcody 2003-10-19
  • 打赏
  • 举报
回复
我又尝试先绑定DataList,然后从中获取一个 DataListItem :
DataListItem li = DataList1.Items[0];
再添加进去:
DataList1.Controls.Add(li);

结果是:索引超出范围。必须为非负值并小于集合大小。

我昏~~~~~~,我绑定之后的DataList.Items应该是有效集合阿,那为什么会出现索引异常呢?
badcody 2003-10-19
  • 打赏
  • 举报
回复
Table 表 = new Table();
TableRow 行 = new TableRow();
TableCell 列 = new TableCell();

列.Text = "1";
行.Cells.Add(列);
表.Rows.Add(行);

这个表生成是没有问题,但是不能将 行 或 列 添加到DataList,而且很奇怪的是,
这句代码:DataList1.Controls.Add(行);可以编译通过,而且运行时不会抛出异常,但页面显示的是
-----------------------------------------------------------------------
异常详细信息: System.InvalidCastException: 指定的转换无效。

源错误:

执行当前 Web 请求期间生成了未处理的异常。可以使用下面的异常堆栈跟踪信息确定有关异常原因和发生位置的信息。
-----------------------------------------------------------------------


badcody 2003-10-19
  • 打赏
  • 举报
回复
DataListItem dli = new DataListItem(1,ListItemType.Item);
dli.Controls.Add(new LiteralControl("****hello****"));
DataList1.Controls.Add(dli);

很奇怪的是,为什么这段代码执行之后,DataList没有任何变化呢?而且也没有扔出异常。

按理说,DataList1的Controls就是DataListItem类型的控件集合阿,那再添加一个DataListItem为什么就没有反应呢?
hiaming 2003-10-19
  • 打赏
  • 举报
回复
那么,在DataGrid中,也能动态生成一行并加入吗?
不要修改数据库或dataSet
Nicholasqpl 2003-10-19
  • 打赏
  • 举报
回复
同意saucer(思归) 老大的!
up
saucer 2003-10-19
  • 打赏
  • 举报
回复
you can try

DataListItem dli = new DataListItem(0,ListItemType.Item);
dli.Controls.Add(new LiteralControl("****hello****"));
dl.Controls.AddAt(10,dli);

but it doesn't seem to work, if you want the ultimate flexibility, use Table/TableRow/TableCell instead
badcody 2003-10-18
  • 打赏
  • 举报
回复
哦,谢谢思归的回复。

我想再问问,能够在不修改绑定数据表的情况下,增加数据行吗?

比如我的datalist已经完成绑定,还是这两列"au_lname"、"au_fname"。
那我能添加一列数据进去吗(插入到任意位置?)?

其实这样有些多余...........
srj911 2003-10-18
  • 打赏
  • 举报
回复
学习
suguanqun 2003-10-18
  • 打赏
  • 举报
回复
同意saucer(思归) 老大的!
saucer 2003-10-18
  • 打赏
  • 举报
回复
the simplest way is to insert a row to your DataTable, for example


<%@ Import Namespace="System.Data" %>
<%@ Import Namespace="System.Data.SqlClient" %>
<form runat=server>
<asp:DataList id="dl" runat=server BorderWidth="1" GridLines="Both">
<ItemTemplate>
<%# Container.ItemIndex + 1%>:
<%# DataBinder.Eval(Container.DataItem,"au_lname")%>,
<%# DataBinder.Eval(Container.DataItem,"au_fname")%>
</ItemTemplate>
</asp:DataList>
</form>

<script language="C#" runat="server">
void Page_Load(Object o, EventArgs e)
{
if (!IsPostBack)
{
SqlDataAdapter da = new SqlDataAdapter("select * from authors", "server=localhost;database=pubs;uid=sa;pwd=;");
DataTable dt = new DataTable();

da.Fill(dt);
DataRow dr = dt.NewRow();
dr["au_lname"] = "hello";
dr["au_fname"] = "world";
dt.Rows.InsertAt(dr, 3);
dl.DataSource = dt.DefaultView;
dl.DataBind();
}
}
</script>

62,025

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

试试用AI创作助手写篇文章吧