6

看起来这个问题在这里得到了解决,但他的解决方案对我不起作用。我正在创建一个动态下拉菜单系统,该系统根据第一个下拉列表中的所选项目使用查询结果填充辅助下拉列表。

第一个下拉列表被填充:

Dim db As New linqclassesDataContext
Dim categories = (From c In db.faq_cats)

NewFaqDropDownCategory.DataSource = categories
NewFaqDropDownCategory.DataTextField = "category"
NewFaqDropDownCategory.DataValueField = "category_id"
NewFaqDropDownCategory.DataBind()
Unset(categories)
Unset(db)

第二个下拉列表被填充:

Protected Sub NewFaqDropDownCategory_SelectedIndexChanged(ByVal sender As Object, ByVal e As System.EventArgs)
    Dim temp As Integer = CInt(Val(NewFaqDropDownCategory.SelectedIndex))
    MsgBox(theDrop.SelectedValue)
    Return

    'Dim db As New linqclassesDataContext
    'Dim faqs = (From f In db.faqs Where f.category = NewFaqDropDownCategory.SelectedValue)

    'NewFaqDropDownList.DataSource = faqs
    'NewFaqDropDownList.DataTextField = "question"
    'NewFaqDropDownList.DataValueField = "id"
    'NewFaqDropDownList.DataBind()
    'NewFaqLabel.Visible = True
    'NewFaqDropDownList.Visible = True
    'Unset(faqs)
    'Unset(db)
End Sub

第一个下拉菜单的标记...

<asp:DropDownList ID="NewFaqDropDownCategory" AutoPostBack="true" runat="server" OnSelectedIndexChanged="NewFaqDropDownCategory_SelectedIndexChanged">
</asp:DropDownList>

而第二...

<asp:DropDownList ID="NewFaqDropDownList" runat="server" Visible="false">
</asp:DropDownList>

无论我尝试了什么,我总是得到“1”(第二个下拉列表中第一项的值)。我之前引用的帖子说这与 AutoPostBack 和服务器不知道列表已更新有关。

任何人都可以为我澄清一下吗?

4

3 回答 3

9

在以下行设置断点:NewFaqDropDownCategory.DataBind() 和事件处理程序中的一个 (NewFaqDropDownCategory_SelectedIndexChanged)。我怀疑在您的 NewFaqDropDownCategory_SelectedIndexChanged 事件触发之前调用了数据绑定,从而导致您选择的值发生更改。

如果是这样,您需要确保仅在您不在自动回发中间时进行数据绑定,或者在事件处理程序的第一行不使用 NewFaqDropDownCategory.SelectedIndex 您可以将 sender 参数转换为 DropDownList 并使用选定的值。

于 2009-03-03T20:22:23.630 回答
2

我有同样的问题。发现我忘记查看是否回发到页面,并且在页面事件中绑定了我的 DropDownList 控件Page_Load。我忘了使用:

if (!IsPostBack)
{
   .... do databind ....
}
于 2009-04-20T11:49:23.693 回答
0

我认为第二个下拉框的 LINQ 查询中有一个错误

Dim faqs = (From f In db.faqs Where f.category = NewFaqDropDownCategory.SelectedValue)

在这里,您将 SelectedValue 与类别进行比较。然而,在第一个组合框中,您说 DataValueField 应该是 category_id。尝试将 f.category 更改为 f.category_id

于 2009-03-03T20:21:35.583 回答