Kendo UI Autocomplete使用2个单词(名字和姓氏)

时间:2014-12-01 15:01:48

标签: javascript c# autocomplete kendo-ui kendo-autocomplete

即使用户输入了第一个和第二个名字,我目前正试图获得一个kendo ui自动完成功能来显示结果。目前,如果自动填充包含第一个或第二个名称,我目前的代码正常工作。我希望自动完成功能仍能显示结果,例如,如果Peter S'进入后它仍会显示“彼得史密斯”的结果。和彼得三星'。如果有人可以查看我的代码,并且可能指出我正确的方向,这将是伟大的。我花了很多时间在这上面,我想我可能采取了错误的方法。

以下代码:

                $("#FeeEarnerEmailSend").kendoAutoComplete({
                    dataSource: new kendo.data.DataSource({
                        serverFiltering: true,
                        transport: {
                            read: "/" + prefix + "/api/Session/GetEmployees",
                            parameterMap: function () {
                                return { id: $("#FeeEarnerEmailSend").data("kendoAutoComplete").value() };
                            }
                        }
                    }),
                    dataTextField: 'FullName',
                    filter: "contains",
                    //placeholder: "Search...",
                    minLength: 3,
                    suggest: true,
                    select: function (e) {
                        var employeeAutoComplete = e.sender;
                        // this var is used in the Search button click event
                        selectedEmployeeDataItem = employeeAutoComplete.dataItem(e.item.index());
                    },
                    change: function () {
                        if ($.trim($("#FeeEarnerEmailSend").val()) == "") {
                            selectedEmployeeDataItem = null;
                        }
                    },
                    dataBound: function (e) {
                        selectedEmployeeDataItem = e.sender.dataItem(0);

                    }
                });

这是我的Csharp代码,我认为这个问题可能存在于我的linq中,需要编辑来实现这个目标吗?

     [HttpGet]
    [Route("api/Session/GetEmployees")]
    public IHttpActionResult GetEmployees(string id)
    {
        logger.Trace("Get Employees - {0} -  based on prefix", id);
        try 
        { 
            DirectoryContext context = new DirectoryContext(new Uri(ConfigurationManager.AppSettings["DirectoryServiceUrl"]));

            var result = from q in context.Employees
                         where q.Surname.Contains(id) || q.KnownAs.Contains(id)
                         orderby q.Surname, q.KnownAs
                         select new
                         {
                             NetworkId = q.NetworkID,
                             FullName = String.Format("{0} {1}", q.Surname.ToUpper(), q.KnownAs),
                             EmailAddress = q.EmailAddress
                         };
            logger.Info("Returning Employees - {0}", id);
            return Ok(result.ToList());


        }
        catch (Exception ex)
        {
            logger.Error(ex.Message, ex);
            return InternalServerError(ex);
        }
    }

0 个答案:

没有答案