Можем ли мы связать .asmx с элементом управления asp.net? - PullRequest
2 голосов
/ 06 апреля 2011

У меня есть файл .asmx, который я использую для передачи данных в мой AutoCompleteExtender (Ajax AutoCompleteExtender из AJAX Toolkit ). Это AutoCompleteExtender взаимодействует с хранимой процедурой в базе данных SQL.

Вот проблема: пользователь может выбрать фильтр для поиска в базе данных (имя, адрес, название и т. Д.). Этот фильтр применяется с DropDownList. Если я хочу, чтобы автозаполнение работало правильно, я должен применить фильтр к автозаполнению. В настоящее время я пытаюсь использовать SelectedIndex DropDownList для применения фильтра.

т.е.: если пользователь выбирает адрес, я не должен давать подсказки для автозаполнения имен.

Если я добавлю фильтр по умолчанию в файл .asmx, автозаполнение будет работать (т.е. имена), процедура sql не будет иметь проблем, как и страница aspx. Я хочу знать, есть ли способ получить SelectedIndex DropDownList в файле .asmx или любой другой способ сделать то же самое.

Вот код

TextBox + AutoCompleteExtender:

<asp:TextBox ID="txtValue" runat="server"  style="margin-bottom: 0px"></asp:TextBox>
<asp:AutoCompleteExtender ID="AutoCompleteExtenderSearchValue" runat="server" ServicePath="AutoComplete.asmx" 
    ServiceMethod="GetSuggestions"  TargetControlID="txtValue" MinimumPrefixLength="1" CompletionSetCount="10"
    EnableCaching="true" UseContextKey="true" ShowOnlyCurrentWordInCompletionListItem="true"></asp:AutoCompleteExtender>

Функция для получения моих данных для AutoCompleteExtender в .asmx:

//will get all the suggestions from what the user typed.
public string[] GetSuggestions(string prefixText, int count, string contextKey)
{
    string name = null;
    string surname = null;
    string givenName = null;
    string title = null;
    string phone = null;
    string department = null;
    string location = null;
    DataTable dt = null;

    List<string> suggestions = new List<string>();
    dt = new DataTable("Users");

    //pr_SEL_Usr
    SqlCommand cmd = new SqlCommand(ConfigManager.SelUser);
    cmd.CommandType = CommandType.StoredProcedure;

    //set the parameters
    cmd.Parameters.Add("@Name", SqlDbType.VarChar).Value = name;
    cmd.Parameters.Add("@Surname", SqlDbType.VarChar).Value = surname;
    cmd.Parameters.Add("@GivenName", SqlDbType.VarChar).Value = givenName;
    cmd.Parameters.Add("@Title", SqlDbType.VarChar).Value = title;
    cmd.Parameters.Add("@Phone", SqlDbType.VarChar).Value = phone;
    cmd.Parameters.Add("@Division", SqlDbType.VarChar).Value = department;
    cmd.Parameters.Add("@Location", SqlDbType.VarChar).Value = location;
    cmd.Parameters.Add("@User_cd", SqlDbType.VarChar).Value = null;

    dt = DBUtils.Execute(cmd);

    for (int i = 0; i < dt.Rows.Count; i++)
    {
        if (i < count)
            suggestions.Add(dt.Rows[i][5].ToString());
        else
            break;
    }

    return suggestions.ToArray();
}

Я попытался добавить индекс переменной к функции и использовать регистр для установки параметра, но это не сработало. Я искал в Интернете способ сделать это, но безрезультатно. .net

Ответы [ 2 ]

0 голосов
/ 06 апреля 2011

Установите AutoPostBack="true" в раскрывающемся списке фильтра.

Добавить событие SelectedIndexChanged в раскрывающийся список фильтров. В этом методе события установите свойство ContextKey для AutoCompleteExtender.

protected void FilterDropDownList_SelectedIndexChanged(object sender, EventArgs e)
{
    AutoCompleteExtenderSearchValue.ContextKey = FilterDropDownList.SelectedValue;
}

Теперь ваш GetSuggestions метод ASMX должен получить значение раскрывающегося списка фильтра через параметр contextKey.

0 голосов
/ 06 апреля 2011

Ваш веб-сервис не может ссылаться на элементы управления на вашей странице.В тот момент, когда ваш JavaScript вызывает службу, объект страницы больше не существует.

Можно предположить, что ваша веб-служба использует состояние сеанса.Затем вы можете добавить новый вызов, чтобы передать настройки фильтра со своей страницы в службу.Когда расширитель автозаполнения вызывает службу, эта информация фильтра будет по-прежнему в состоянии сеанса, где вы сохранили ее в предыдущем вызове.

...