0

我正在尝试过滤我的结果,但无法弄清楚如何设置 ajax 查询以与 select2 下拉菜单一起正常工作。据我所知,您应该使用数据,但这不仅仅是传递值并过滤我的调用。

这是我的ajax:

            $('#e1').select2({
                placeholder: "Select an ingredient...",
                minimumInputLength: 2,
                ajax: {
                    url: "../api/IngredientChoices",
                    data: 'mi',
                    dataType: "json",
                    quietMillis: 500,
                    data: function (term, page) {
                        return {
                            q: term,
                            page_limit: 10,
                            page: page

                        };
                    },
                    results: function (data, page) {
                        var more = (page * 10) < data.length;
                        console.log(more);
                        console.log(data);
                        return { results: data, more: more };

                    },
                    formatResult: function (post) {
                        markup = '<strong>' + post.text + '</strong>';
                    }
                }
            });

这是我的控制器:

    public List<Models.IngredientChoices> Get(string param)
    {
        var choices = (from i in _context.IngredientItems_View(param)

                       select new Models.IngredientChoices
                       {
                           id = i.ItemID,
                           text = i.ConcatName,
                       });
        return choices.ToList();
    }

ajax 调用当前返回所有值。

4

2 回答 2

0

你的 ajax 上有一个重复的成员data:- 你应该只有一个。

编辑:只是一个 SWAG,但也许你需要一个类:

class myparam {
  string q ;
  int page_limit;
  int page;
}
//decorate for JSON
public List<Models.IngredientChoices> Get(myparm param)
{
    var choices = (from i in _context.IngredientItems_View(param.q)
于 2013-01-25T20:04:45.370 回答
0

正如@jmordyk 所说,答案是我的q:术语与我在 c# 中的参数不匹配。我改变了这一行:

public List<Models.IngredientChoices> Get(string param)

成为:

public List<Models.IngredientChoices> Get(string q)
于 2013-01-25T21:38:24.937 回答