首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >DevExpress ASPxComboBox SelectItem为空

DevExpress ASPxComboBox SelectItem为空
EN

Stack Overflow用户
提问于 2011-06-15 20:34:55
回答 2查看 11.6K关注 0票数 1

我有一个能够正确过滤用户输入的ASPxComboBox。现在,我想将所选项目保存到数据库中。但是当我尝试获取SelectedItem时,它是空的。

ASP

代码语言:javascript
复制
<dxe:ASPxComboBox ID="cboInstructor" runat="server" Width="100%"
            EnableCallbackMode="True" CallbackPageSize="10"
            IncrementalFilteringMode="Contains" ValueType="System.Int32" ValueField="employee_id"
            OnItemsRequestedByFilterCondition="cboInstructor_OnItemsRequestedByFilterCondition_SQL"
            OnItemRequestedByValue="cboInstructor_OnItemRequestedByValue_SQL" TextFormatString="{0} {1}"
            DropDownStyle="DropDown"
        >
            <Columns>
                <dxe:ListBoxColumn FieldName="display_forename" Caption="Forename" />
                <dxe:ListBoxColumn FieldName="display_surname" Caption="Surname" />
            </Columns>
        </dxe:ASPxComboBox>

        <asp:SqlDataSource ID="SqlDataSourceInstruct" runat="server" ConnectionString="Server=testserver;User ID=root;Password=password;Persist Security Info=True;Database=central" ProviderName="MySql.Data.MySqlClient" SelectCommand="GetUser" SelectCommandType="StoredProcedure">
            <SelectParameters>
                <asp:Parameter Name="filter" Type="String" />
                <asp:Parameter Name="startIndex" Type="Int32" />
                <asp:Parameter Name="endIndex" Type="Int32" />
            </SelectParameters>
        </asp:SqlDataSource>
        <asp:SqlDataSource ID="SqlDataSourceInstructPopulate" runat="server" ConnectionString="Server=testserver;User ID=root;Password=password;Persist Security Info=True;Database=central" ProviderName="MySql.Data.MySqlClient" SelectCommand="GetUser" SelectCommandType="StoredProcedure">
        </asp:SqlDataSource>

        <asp:Button ID="btnTest" runat="server" Text="Test" OnClick="btnTest_Click" />

政务司司长

代码语言:javascript
复制
    protected void Page_Load(object sender, EventArgs e)
    {

    }

    protected void cboInstructor_OnItemsRequestedByFilterCondition_SQL(object source, ListEditItemsRequestedByFilterConditionEventArgs e)
    {
        ASPxComboBox comboBox = (ASPxComboBox)source;

        SqlDataSourceInstruct.SelectParameters.Clear();
        SqlDataSourceInstruct.SelectParameters.Add("filter", TypeCode.String, string.Format("%{0}%", e.Filter));
        SqlDataSourceInstruct.SelectParameters.Add("startIndex", TypeCode.Int32, (e.BeginIndex + 1).ToString());
        SqlDataSourceInstruct.SelectParameters.Add("endIndex", TypeCode.Int32, (e.EndIndex + 1).ToString());
        comboBox.DataSource = SqlDataSourceInstruct;
        comboBox.DataBind();
    }

    protected void cboInstructor_OnItemRequestedByValue_SQL(object source, ListEditItemRequestedByValueEventArgs e)
    {
        long value = 0;
        if (e.Value == null)
            return;
        if (!Int64.TryParse(e.Value.ToString(), out value))
            return;
        ASPxComboBox comboBox = (ASPxComboBox)source;
        SqlDataSourceInstructPopulate.SelectCommand = @"SELECT employee_id, display_surname, display_forename FROM user_record WHERE employee_id = @ID ORDER BY display_forename";
        SqlDataSourceInstructPopulate.SelectCommandType = System.Web.UI.WebControls.SqlDataSourceCommandType.Text;
        SqlDataSourceInstructPopulate.SelectParameters.Clear();
        SqlDataSourceInstructPopulate.SelectParameters.Add("ID", TypeCode.Int64, e.Value.ToString());
        comboBox.DataSource = SqlDataSourceInstructPopulate;
        comboBox.DataBind();
        comboBox.ValueField = "employee_id";
    }

    protected void btnTest_Click(object sender, EventArgs e)
    {
        int iTest = (int)cboInstructor.SelectedItem.GetValue("employee_id");
    }

在这一行:

代码语言:javascript
复制
int iTest = (int)cboInstructor.SelectedItem.GetValue("employee_id");

cboInstructor.SelectedItem为空。有人知道为什么吗?

EN

回答 2

Stack Overflow用户

发布于 2011-07-27 09:06:50

安东尼

SelectedItem用于指定要选择的项。在ASPxComboBox中选择项后,可以使用Value或Text属性来引用它。

http://documentation.devexpress.com/#AspNet/DevExpressWebASPxEditorsASPxComboBoxMembersTopicAll

这个帖子也可能对你有帮助:http://community.devexpress.com/forums/t/61424.aspx

谢谢。

票数 1
EN

Stack Overflow用户

发布于 2015-08-13 15:57:39

我知道这个问题很老了,但是以防有人在看它。以下是其他可能的解决方案:

  1. 确保值与您的表中的实际‘ValueType’类型匹配。有些值类型不会自动填充,比如"System.Guid“。但它们是可用的。本质上,DevExpress将使用您的表正在使用的任何值类型,即使它没有列出,如果您手动键入它,它将获取它。
  2. 根据设计,ASPxComboBox不会与服务器端同步。要解决此问题,请始终在每次页面请求时绑定ASPxComboBox。因此基本上您的页面加载将如下所示

SqlDataSourceInstruct.SelectParameters.Clear();SqlDataSourceInstruct.SelectParameters.Add("filter",TypeCode.Int32,(e.BeginIndex + 1).ToString());protected void TypeCode.Int32,(e.EndIndex + 1).ToString());cboInstructor.DataSource = SqlDataSourceInstruct;cboInstructor.DataBind();}

理想情况下,您应该有一个重新加载ASPxComboBox的方法,您只需调用该方法,而不是每次都重复此代码

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/6357739

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档