将数据绑定到 30 个下拉列表的最简单方法是什么?

发布于 2024-11-04 06:37:08 字数 1041 浏览 1 评论 0原文

我的问题很简单。这是我的场景:

  1. 我里面有 1 个结果数据集 [named="resultDS" typed="MyDataset"] 和 1 个数据表 [MyDT]。
  2. 在数据表中,我有10行,每行在
  3. aspx页面上有3列[Column1,Column2,Column3],我有30个drowdownlists等待上面的数据

dataTable中的数据将是:

Column1 | Column1 | Column3第 2 栏 |第 3 栏

方法 1 | 100 | 100 0.5

方法2 | 125 | 125 0.75

方法3 | 80| 0.4

。 。 。

方法30 | 200 | 200 1

目前,我使用最简单的方式来绑定数据。例如:

ddl1.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column1;
ddl2.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column2;
ddl3.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column3;

ddl4.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column1;
ddl5.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column2;
ddl6.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column3;
.
.
.
ddl30.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[9]).Column3;

有没有比我当前的方法更容易将数据绑定到我的 ddl 的方法?

谢谢。

瓦查

my question is very simple. here is my scenario:

  1. i have 1 result dataset[named="resultDS" typed="MyDataset"] and 1 datatable[MyDT] inside.
  2. in datatable, i have 10 rows, each row has 3 columns [Column1,Column2,Column3]
  3. on aspx page, i have 30 drowdownlists waiting for above data

The data inside dataTable will be:

Column1 | Column2 | Column3

Method1 | 100 | 0.5

Method2 | 125 | 0.75

Method3 | 80 | 0.4

.
.
.

Method30 | 200 | 1

currently, i used the simplest way for binding data. something like:

ddl1.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column1;
ddl2.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column2;
ddl3.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[0]).Column3;

ddl4.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column1;
ddl5.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column2;
ddl6.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[1]).Column3;
.
.
.
ddl30.SelectedValue = ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[9]).Column3;

Is there any way to bind data to my ddl easier than my current method?

Thank you.

vcha

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

豆芽 2024-11-11 06:37:09

假设代码中的最后一行有 Rows[9]

您可以尝试在循环中执行此操作

for (int i=0; i<30; i++)
{
   DropDownList ddl = (DropDownList) FindControl("ddl"+(i+1));

   switch (i % 3)
   {
      case 0:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column1;
          break;
      case 1:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column2;
          break;
      case 2:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column3;
          break;
    }
}

Assuming the last line in you code has Rows[9]

You can try doing it in a loop

for (int i=0; i<30; i++)
{
   DropDownList ddl = (DropDownList) FindControl("ddl"+(i+1));

   switch (i % 3)
   {
      case 0:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column1;
          break;
      case 1:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column2;
          break;
      case 2:
          ddl.SelectedValue =  ((MyDataSet.MyDTRow)resultDS.MyDT.Rows[i/3]).Column3;
          break;
    }
}
离线来电— 2024-11-11 06:37:09

我会在 Databound 控件(例如 ListViewGridView)中进行设置。

这将允许您创建将重复的 3 个 ddls,然后将 SelectedItemValue 绑定到您的列。

我根据您所证明的情况做出一些假设,这对您有用。如果 ddls 分散在整个站点中,则可能不会。

I would set this up in a Databound control Like a ListView or GridView.

This will allow you to Create the 3 ddls that will be repeated then bind the SelectedItemValue to your column.

I am making some assumptions based on what you have shown that this will work for you. If the ddls are scattered throughout the site then it may not.

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文