使用DropDown控件过滤GridView时遇到问题

时间:2012-04-26 21:05:19

标签: asp.net ado.net

我正在尝试使用下拉列表过滤网格视图,但是看起来选中的下拉列值没有进入我的SqlDataSource控件。 (我是asp.net的新手,这是我正在研究的教程。)

当我删除SelectParameters部分并将一个有效的LastName插入gridview的select语句的where子句时,我得到了一个过滤的gridview,但是当我从中选择一个名字时,它不起作用。下拉列表。

这可能是VS版本的东西。我正在使用VS 2010(w / .Net 3.5),本书使用VS 2008。

代码:

<%@ Page Language="C#" AutoEventWireup="true" CodeFile="SqlDataSourceParameters_3.aspx.cs" Inherits="SqlDataSourceWizard" %>

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title></title>
</head>
<body>
    <form id="form1" runat="server">
    <div>

    </div>
    <asp:SqlDataSource ID="CustomersDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorksConnectionString %>" 

        SelectCommand="SELECT [FirstName], [LastName], [EmailAddress], [ModifiedDate] FROM [Person].[Contact] WHERE ([LastName] = @LastName)">
        <SelectParameters>
            <asp:ControlParameter ControlID="DropDownList1" 
                Name="LastName" PropertyName="SelectedValue" Type="String" />
        </SelectParameters>
    </asp:SqlDataSource>
    <asp:GridView ID="CustomerGridView" runat="server" AutoGenerateColumns="False" 
        DataSourceID="CustomersDataSource" EnableModelValidation="True">
        <Columns>
            <asp:BoundField DataField="FirstName" HeaderText="FirstName" 
                SortExpression="FirstName" />
            <asp:BoundField DataField="LastName" HeaderText="LastName" 
                SortExpression="LastName" />
            <asp:BoundField DataField="EmailAddress" HeaderText="EmailAddress" 
                SortExpression="EmailAddress" />
            <asp:BoundField DataField="ModifiedDate" HeaderText="ModifiedDate" 
                SortExpression="ModifiedDate" />
        </Columns>
    </asp:GridView>
    <asp:SqlDataSource ID="StaffDataSource" runat="server" 
        ConnectionString="<%$ ConnectionStrings:AdventureWorksConnectionString2 %>" 
        SelectCommand="SELECT DISTINCT [LastName] FROM [Person].[Contact] ORDER BY 1"></asp:SqlDataSource>
    <asp:DropDownList ID="DropDownList1" runat="server" 
        DataSourceID="StaffDataSource" DataTextField="LastName" 
        DataValueField="LastName">
    </asp:DropDownList>
    </form>
</body>
</html>

1 个答案:

答案 0 :(得分:1)

也许我在这里遗漏了一些东西,但是什么导致了回发?我没有看到按钮,也没有看到下拉列表的autopostback属性设置为true。您的代码是否在做某事(比如设置下拉列表的默认值)?