He leído muchas publicaciones con el mismo problema, pero ninguna ayuda, por lo que me disculpo por la pregunta duplicada :( He seguido la muestra simple en el sitio JQueryUI codificando valores y el autocompletado funciona, pero necesito que venga de mi Base de Datos.

Vista:

@Html.TextBoxFor(model => model.Position, new { @type = "text", @id = "jobtitle", @name = "jobtitle", @placeholder = "Job Title" })

Js:

EDITAR : agregué una alerta de éxito, y se está llamando a la alerta, pero no hay datos (es decir, no se extraen datos de la base de datos)

<script>
$(function () {
            $("#jobtitle").autocomplete({
                source: function (request, response) {
                    $.ajax({
                        url: '@Url.Action("JobsAutoFill", "Account")',
                        data: {
                            Prefix: request.term
                        },
                        success: function (data) {
                            alert(data);
                            response(data);
                        }
                    });
                },
                minLength: 1
            });

            //$("#jobtitle").autocomplete({
            //    source: "/Account/JobsAutoFill/"
            //});
        });
</script>

Y he agregado los enlaces necesarios:

<script src="https://code.jquery.com/jquery-1.12.4.js"></script>
<script src="https://code.jquery.com/ui/1.12.1/jquery-ui.js"></script>

A continuación se muestra mi ActionResult (en realidad, un JsonResult) y la función para extraer la lista de trabajos:

    public List<Jobs> GetAllJobs()
    {
        List<Jobs> JobsList = new List<Jobs>();

        using (RBotEntities EF = new RBotEntities())
        {
            var JobsListQuery = (from ED in EF.EmploymentDetails
                                   select new
                                   {
                                       ED.pkiEmploymentDetailID,
                                       ED.Position
                                   });

            foreach (var item in JobsListQuery)
            {
                JobsList.Add(new Jobs
                {
                    Id = item.pkiEmploymentDetailID,
                    Name = item.Position
                });
            }
        }

        return JobsList;
    }

public JsonResult JobsAutoFill(string Prefix)
        {
            //Note : you can bind same list from database  


            List<Jobs> ObjList = new List<Jobs>();

            ObjList = GetAllJobs();

            //Searching records from list using LINQ query  


            var JobNames = (from N in ObjList
                            where N.Name.StartsWith(Prefix)
                            select new { N.Name });
            return Json(JobNames, JsonRequestBehavior.AllowGet);
        }

¿Me estoy perdiendo algo o estoy haciendo algo mal?

Agradezco cualquier ayuda, gracias!

14
AxleWack 16 feb. 2017 a las 11:29

3 respuestas

La mejor respuesta

Lo tengo funcionando!

Lo primero que estaba causando un problema era que necesitaba agregar [AllowAnonymous] sobre mi ActionResult.

En segundo lugar, cambié mi llamada Ajax a esto:

$(function () {
    $("#jobtitle").autocomplete({
        source: function (request, response) {
            $.ajax({
                url: '@Url.Action("JobsAutoFill", "Account")',
                data: {
                    Prefix: request.term
                },
                success: function (data) {
                    response($.map(data, function (obj) {
                        return {
                            label: obj.Name,
                            value: obj.Name
                        };
                    }));
                }
            });
        },
        minLength: 1
    });
});

A continuación se muestra mi ActionResult. Agregué un cambio que resolvería las mayúsculas y minúsculas:

[AllowAnonymous]
public JsonResult JobsAutoFill(string Prefix)
{
    //Note : you can bind same list from database  


    List<Jobs> ObjList = new List<Jobs>();

    ObjList = GetAllJobs();

    //Searching records from list using LINQ query  


    var JobNames = (from N in ObjList
                    where N.Name.ToLower().StartsWith(Prefix.ToLower())
                    select new { N.Name });
    return Json(JobNames, JsonRequestBehavior.AllowGet);
}
12
AxleWack 23 feb. 2017 a las 10:33

No debe hacerlo AllowAnonymous si no tiene que tener acceso público. Y en segundo lugar cambie su consulta para un mejor rendimiento:

var JobNames = (from N in ObjList
                where N.Name.ToLower().StartsWith(Prefix.ToLower())
                select N.Name);

Obviamente, debe devolver una matriz de cadenas. Pero su código está devolviendo una matriz de objetos que tiene una propiedad de cadena única.

Y cambie su código de script según las actualizaciones:

success: function (data) {
                    response($.map(data, function (obj) {
                        return {
                            label: obj,
                            value: obj
                        };
                    }));
                }
2
ArgeKumandan 25 abr. 2017 a las 05:38

No cambiar permitir anónimo cambiar su llamada ajax de esa manera pasar su parámetro en la cadena de consulta, esto afectará su función de back-end. Espero que esto te ayudará

$(function () {
$("#jobtitle").autocomplete({
    source: function (request, response) {
        $.ajax({
            url: '@Url.Action("JobsAutoFill", "Account")?Prefix='+$("#jobtitle").val(),
            data: {
                Prefix: request.term
            },
            success: function (data) {
                response($.map(data, function (obj) {
                    return {
                        label: obj.Name,
                        value: obj.Name
                    };
                }));
            }
        });
    },
    minLength: 1
});

});

2
nazar tvm 1 mar. 2017 a las 01:06