Вызов jquery ajax не работает при изменении фреймворка с 3.5 на 4.0

проверено с предупреждением .. но вызов ajax не работает, а мой aspx.cs когда я меняю свою структуру .net с 3.5 на 4.0

моя функция ajax

function GetCustomers(pageIndex) {
            $.ajax({
                type: "POST",
                url: "Webusers.aspx/GetCustomers",
                data: '{searchTerm: "' + SearchTerm() + '", pageIndex: ' + pageIndex + '}',
                contentType: "application/json; charset=utf-8",
                dataType: "json",
                success: OnSuccess,
                failure: function (response) {
                    alert(response.d);
                },
                error: function (response) {
                    alert(response.d);
                }
            });
        }

и мой метод .cs

 [WebMethod(EnableSession = true)]


 public static string GetCustomers(string searchTerm, int pageIndex)
    {

        string query = "SearchWebUserData";
        if (!string.IsNullOrEmpty(HttpContext.Current.Request.Form["gender"]))
        {
            string sSeraachType = HttpContext.Current.Request.Form["gender"];
        }
        SqlCommand cmd = new SqlCommand(query);
        cmd.CommandType = CommandType.StoredProcedure;
        cmd.Parameters.AddWithValue("@SearchTerm", searchTerm);
        cmd.Parameters.AddWithValue("@PageIndex", pageIndex);
        cmd.Parameters.AddWithValue("@PageSize", PageSize);
        cmd.Parameters.AddWithValue("@flag", "E");
        cmd.Parameters.Add("@RecordCount", SqlDbType.Int, 4).Direction = ParameterDirection.Output;
        return GetData(cmd, pageIndex).GetXml();
    }

Изменение версии .Net framework не повлияет на код JS. Более вероятно, что C# сломан и возвращает 500. Я бы посоветовал проверить журнал в браузере, чтобы увидеть ответ, а затем пройти через ваш метод GettCustomers(), чтобы найти, где ошибка.

Rory McCrossan 11.06.2018 09:32

Также обратите внимание, что вам не нужно собирать строку JSON. Просто передайте объект jQuery, и он будет преобразовывать его в строку: data: { searchTerm: SearchTerm(), pageIndex: pageIndex }

Rory McCrossan 11.06.2018 09:33

он работал, когда это был framework 3.5

Tanmay Nehete 11.06.2018 09:35

Вы проверяли в консоли браузера, что возвращается, есть ли ошибки? Также, когда / если вы отлаживаете и устанавливаете точку останова, происходит ли это? Если да, вы прошли через код?

Izzy 11.06.2018 09:36

он возвращает undefind

Tanmay Nehete 11.06.2018 09:38

Вы пробовали alert(response) и смотрели, есть ли еще что-нибудь в ответе?

Izzy 11.06.2018 09:44

не только получить Undefine

Tanmay Nehete 11.06.2018 09:46

И вы не можете установить точку останова и пройти через нее?

Izzy 11.06.2018 09:48

да, когда точка останова появляется на ajax, она просто пропускается

Tanmay Nehete 11.06.2018 10:55
Стоит ли изучать PHP в 2026-2027 годах?
Стоит ли изучать PHP в 2026-2027 годах?
Привет всем, сегодня я хочу высказать свои соображения по поводу вопроса, который я уже много раз получал в своем сообществе: "Стоит ли изучать PHP в...
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Приемы CSS-макетирования - floats и Flexbox
Приемы CSS-макетирования - floats и Flexbox
Здравствуйте, друзья-студенты! Готовы совершенствовать свои навыки веб-дизайна? Сегодня в нашем путешествии мы рассмотрим приемы CSS-верстки - в...
Тестирование функциональных ngrx-эффектов в Angular 16 с помощью Jest
В системе управления состояниями ngrx, совместимой с Angular 16, появились функциональные эффекты. Это здорово и делает код определенно легче для...
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Пользовательский скаляр GraphQL
Пользовательский скаляр GraphQL
Листовые узлы системы типов GraphQL называются скалярами. Достигнув скалярного типа, невозможно спуститься дальше по иерархии типов. Скалярный тип...
0
9
276
1

Ответы 1

Прежде всего убедитесь, что у вас есть действительные сопоставления обработчиков в web.config, как показано ниже:

<system.web>
  <httpHandlers>
    <remove verb = "*" path = "*.asmx"/>
    <add verb = "*" path = "*.asmx" validate = "false" type = "System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
    <add verb = "*" path = "*_AppService.axd" validate = "false" type = "System.Web.Script.Services.ScriptHandlerFactory, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35"/>
    <add verb = "GET,HEAD" path = "ScriptResource.axd" type = "System.Web.Handlers.ScriptResourceHandler, System.Web.Extensions, Version=1.0.61025.0, Culture=neutral, PublicKeyToken=31bf3856ad364e35" validate = "false"/>
  </httpHandlers>
</system.web>

Просто передайте объект в jQuery, и он будет преобразован в строку за вас:

  data: { 'searchTerm':"'+ SearchTerm()+'", 'pageIndex': "'+pageIndex+'" }

Вы отправляете "'+ SearchTerm()+'" и "'+pageIndex+'" как буквальные строковые значения в объекте во втором примере.

Rory McCrossan 11.06.2018 09:41

Другие вопросы по теме