0

我已经设法使用 Web 服务在 C#.net 中获得 JQuery 自动完成功能。

这是asp代码:

    <div class="row">
    <div class="span4">
        <h3>
            Manage Season</h3>
    </div>
</div>
<div class="row">
    <div class="span2">
        <p>
            <label class="control-label" for="TeamName">
                Team Name:</label></p>
    </div>
    <div class="span3">
        <asp:TextBox ID="TeamNameTextBox" runat="server" CssClass="searchinput"></asp:TextBox>
        <asp:Button ID="AddTeamButton" CssClass="btn btn-primary" runat="server" Text="Add"
            OnClick="AddTeamButton_Click" />
    </div>
<script type="text/javascript">
    $(document).ready(function () {
        $(".searchinput").autocomplete({
            source: function (request, response) {
                $.ajax({
                    type: "POST",
                    contentType: "application/json; charset=utf-8",
                    url: "PredictiveSearch.asmx/GetAllPredictions",
                    data: "{'keywordStartsWith':'" + request.term + "'}",
                    dataType: "json",
                    async: true,
                    success: function (data) {
                        response(data.d);

                    },
                    error: function (result) {
                        alert("Due to unexpected errors we were unable to load data");
                    }
                });
            },
            minLength: 1
        });
    });
</script>

和 c# 网络服务:

    [System.Web.Script.Services.ScriptService]
public class PredictiveSearch : System.Web.Services.WebService
{

    [WebMethod]
    public IList<string> GetAllPredictions(string keywordStartsWith)
    {
        //TODO: implement real search here!

        SqlConnection conn = new SqlConnection(WebConfigurationManager.ConnectionStrings["RaiseFantasyLeagueConnectionString"].ConnectionString);
        SqlCommand cmd = new SqlCommand("[dbo].[findEnglishTeams]", conn);
        cmd.CommandType = CommandType.StoredProcedure;

        string searchTerm = keywordStartsWith;
        SqlParameter searchTermParam = new SqlParameter("@searchterm", searchTerm);

        cmd.Parameters.Add(searchTermParam);

        IList<string> output = new List<string>();

        conn.Open();
        SqlDataReader dReader = cmd.ExecuteReader(CommandBehavior.CloseConnection);
        if (dReader.HasRows)
        {
            while (dReader.Read())
            {
                output.Add(dReader["englishTeamName"].ToString());
            }
            return output;
        }
        else
        {
            return output; 
        }
    }
}

我需要获取填充下拉列表的值的 ID,这怎么可能?

4

2 回答 2

0

由于您使用 Ajax 请求在客户端填充此内容,因此您将不得不:

  1. 通过将所选值写入 html 输入 type=hidden 元素并在表单回发时在服务器端读取它来获取所选值。只是不要忘记input type=hidden通过添加使元素成为服务器端控件runat="server"
  2. 通过另一个 Ajax 请求提交选定的值。
  3. 使用 Request.Params 集合读取选定的值,使用列表框的名称作为键。就像是:

    var selectedValues = Request.Params["select_box_name"];
    

您将无法简单地使用,因为在您通过 Ajax 填充它时ListBox.SelectedValue找不到值。ViewState

我会选择选项3 ...

于 2013-03-18T18:15:42.590 回答
0

希望这样的东西能更好地满足您的需求

于 2013-03-18T18:53:07.600 回答