0

我有 2 个视图模型,1 个设置搜索参数,另一个用于搜索结果。

搜索型号:

 var CustomerSearchViewModel = {
        SearchType: ko.observable(""),
        SearchString: ko.observable(""),
        setSearchType: function (data, element) {
            this.SearchType($(element.target).val());
        }
    }

结果模型:

 var CustomerSearhResultViewModelDS = function (data) {
        var self = this;
        self.CustomerID = ko.observable(data.CustomerID);
        self.CompanyName = ko.observable(data.CustomerName);
        self.CustomerEMail = ko.observable(data.CustomerEMail);
        self.CustomerTelephone = ko.observable(data.CustomerTelephone);
        self.CustomerCompanyName = ko.observable(data.CustomerCompanyName);
        self.CustomerCompanyAddress1 = ko.observable(data.CustomerCompanyAddress1);
        self.CustomerCompanyAddress2 = ko.observable(data.CustomerCompanyAddress2);
        self.CustomerCompanyZipCode = ko.observable(data.CustomerCompanyZipCode);
    }

    var CustomerSearhResultViewModel = function (Customer) {
        var self = this;

        self.Customer = ko.observableArray(Customer);

         $.ajax({
            url: "CreateOrder.aspx/CustomerSearch",
            data: { SearchType: CustomerSearchViewModel.SearchType(), SearchString: CustomerSearchViewModel.SearchString() },
            type: "POST",
            contentType: "application/json; charset=utf-8",
            dataType: "JSON",
            timeout: 10000,
            success: function (Result) {
                var MappedCustomer =
              $.map(Result.d,
             function (item) {
                 return new CustomerSearhResultViewModelDS(item);
             }
               );
                self.Customer(MappedCustomer);
            },
            error: function (xhr, status) {
                alert(status + " - " + xhr.responseText);
            }
        });
    };

我的后端代码:

  [WebMethod]
    [ScriptMethod(ResponseFormat = ResponseFormat.Json)]
    public static List<CustomerAddress> CustomerSearch(int SearchType, string SearchString)
    {
       //int Converted;
       //Int32.TryParse(SearchType,out Converted);

        nopcommerce144Entities entities = new nopcommerce144Entities();
        List<CustomerAddress> json = null;

        switch (SearchType)
        {
            case 0:
                json = (from cr in entities.Addresses
                               where cr.Company.Contains(SearchString)
                               select new CustomerAddress()
                               {
                                   CustomerCompanyName = cr.Company,
                                   CustomerID = (from cid in entities.Affiliates
                                                 join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                                 where cid.AddressId == cr.Id
                                                 select (int)cus.Id).First(),
                                   CustomerCompanyAddress1 = cr.Address1,
                                   CustomerCompanyAddress2 = cr.Address2,
                                   CustomerCompanyZipCode = cr.ZipPostalCode,
                                   CustomerName = cr.FirstName + " " + cr.LastName,
                                   CustomerTelephone = cr.PhoneNumber,
                                   CustomerEMail = cr.Email
                               }
                                ).ToList();

                break;
            case 1:
                json = (from cr in entities.Addresses
                            where cr.City.Contains(SearchString)
                            select new CustomerAddress()
                            {
                                CustomerCompanyName = cr.Company,
                                CustomerID = (from cid in entities.Affiliates
                                              join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                              where cid.AddressId == cr.Id
                                              select (int)cus.Id).First(),
                                CustomerCompanyAddress1 = cr.Address1,
                                CustomerCompanyAddress2 = cr.Address2,
                                CustomerCompanyZipCode = cr.ZipPostalCode,
                                CustomerName = cr.FirstName + " " + cr.LastName,
                                CustomerTelephone = cr.PhoneNumber,
                                CustomerEMail = cr.Email
                            }
            ).ToList();

                break;
            case 2:
                json = (from cr in entities.Addresses
                              where cr.ZipPostalCode.Contains(SearchString)
                              select new CustomerAddress()
                              {
                                  CustomerCompanyName = cr.Company,
                                  CustomerID = (from cid in entities.Affiliates
                                                join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                                where cid.AddressId == cr.Id
                                                select (int)cus.Id).First(),
                                  CustomerCompanyAddress1 = cr.Address1,
                                  CustomerCompanyAddress2 = cr.Address2,
                                  CustomerCompanyZipCode = cr.ZipPostalCode,
                                  CustomerName = cr.FirstName + " " + cr.LastName,
                                  CustomerTelephone = cr.PhoneNumber,
                                  CustomerEMail = cr.Email
                              }
           ).ToList();

                break;
            case 3:
               json = (from cr in entities.Addresses
                                   where cr.FirstName.Contains(SearchString) || cr.LastName.Contains(SearchString)
                                   select new CustomerAddress()
                                   {
                                       CustomerCompanyName = cr.Company,
                                       CustomerID = (from cid in entities.Affiliates
                                                     join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                                     where cid.AddressId == cr.Id
                                                     select (int)cus.Id).First(),
                                       CustomerCompanyAddress1 = cr.Address1,
                                       CustomerCompanyAddress2 = cr.Address2,
                                       CustomerCompanyZipCode = cr.ZipPostalCode,
                                       CustomerName = cr.FirstName + " " + cr.LastName,
                                       CustomerTelephone = cr.PhoneNumber,
                                       CustomerEMail = cr.Email
                                   }
            ).ToList();

               break;
            case 4:
               json = (from cr in entities.Addresses
                           where cr.PhoneNumber.Contains(SearchString)
                           select new CustomerAddress()
                           {
                               CustomerCompanyName = cr.Company,
                               CustomerID = (from cid in entities.Affiliates
                                             join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                             where cid.AddressId == cr.Id
                                             select (int)cus.Id).First(),
                               CustomerCompanyAddress1 = cr.Address1,
                               CustomerCompanyAddress2 = cr.Address2,
                               CustomerCompanyZipCode = cr.ZipPostalCode,
                               CustomerName = cr.FirstName + " " + cr.LastName,
                               CustomerTelephone = cr.PhoneNumber,
                               CustomerEMail = cr.Email
                           }
            ).ToList();

               break;
            case 5:
                json = (from cr in entities.Addresses
                             where cr.Email.Contains(SearchString)
                             select new CustomerAddress()
                             {
                                 CustomerCompanyName = cr.Company,
                                 CustomerID = (from cid in entities.Affiliates
                                               join cus in entities.Customers on cid.Id equals cus.AffiliateId
                                               where cid.AddressId == cr.Id
                                               select (int)cus.Id).First(),
                                 CustomerCompanyAddress1 = cr.Address1,
                                 CustomerCompanyAddress2 = cr.Address2,
                                 CustomerCompanyZipCode = cr.ZipPostalCode,
                                 CustomerName = cr.FirstName + " " + cr.LastName,
                                 CustomerTelephone = cr.PhoneNumber,
                                 CustomerEMail = cr.Email
                             }
                ).ToList();
                break;
        }
        return json;
    }

我想通过 Ajax 帖子将值从 CustomerSearchViewModel 传递给 CustomerSearchResult 使用这一行:

     { SearchType: CustomerSearchViewModel.SearchType(), SearchString: CustomerSearchViewModel.SearchString() },

执行时出现以下错误: *{“消息”:“无效的 JSON 基元:SearchType。”,“StackTrace”:“在 System.Web.Script.Serialization.JavaScriptObjectDeserializer.DeserializePrimitiveObject()\r\n 在 System.Web.Script.Serialization.JavaScriptObjectDeserializer.DeserializeInternal( Int32 深度)\r\n 在 System.Web.Script.Serialization.JavaScriptObjectDeserializer.BasicDeserialize(字符串输入,Int32 depthLimit,JavaScriptSerializer 序列化程序)\r\n 在 System.Web.Script.Serialization.JavaScriptSerializer.Deserialize(JavaScriptSerializer 序列化程序,字符串输入,类型类型,Int32 depthLimit)\r\n 在 System.Web.Script.Serialization.JavaScriptSerializer.Deserialize[T](字符串输入)\r\n 在 System.Web.Script.Services.RestHandler.GetRawParamsFromPostRequest(HttpContext 上下文, JavaScriptSerializer 序列化程序)\r\n 在 System.Web.Script.Services。RestHandler.GetRawParams(WebServiceMethodData methodData, HttpContext context)\r\n at System.Web.Script.Services.RestHandler.ExecuteWebServiceCall(HttpContext context, WebServiceMethodData methodData)","ExceptionType":"System.ArgumentException"}*

4

1 回答 1

1

您应该作为数据对象传递值,而不是字符串。

这应该是:

data: {CustomerSearchViewModel.SearchType(), CustomerSearchViewModel.SearchString()}

您还应该将其称为函数,因为它是可观察的。

您还应该在 FireBug 或其他控制台工具中检查 JSON 向服务器发送的内容。

我希望它有帮助

于 2013-02-11T08:07:13.497 回答