Autocomplete in ASP.NET MVC3自动检索并填充输入框

1、单一产品情况下使用:

public ActionResult GetStockList()
{
    var item = _db.Stocks.ToList().Select(s =>s.Product.CodePro);
    return Json(item, JsonRequestBehavior.AllowGet);
}
<script type="text/javascript">
    $(function () {
        var url = "/Mana/BillOfLading/GetStockList";
        $.getJSON(url, null, function (myData) {
            var availableTags = myData;
            $("#stockid").autocomplete({
                source: availableTags
            });
        });
    });
  </script>
<div class="ui-widget">
     <label for="stockid">Tags: </label>
     <input id="stockid" />
</div>

 2、多组返回值的情况下:

<link rel="stylesheet" href="http://code.jquery.com/ui/1.10.3/themes/smoothness/jquery-ui.css" />
<script src="../../Scripts/jquery-ui-1.8.11.min.js" type="text/javascript"></script>
<script type="text/javascript">
    $(function () {
        $("#SearchString").autocomplete({
            source: "/Student/AutocompleteSuggestions",
            minLength: 1,
            select: function (event, ui) {
                if (ui.item) {
                    $("#SearchString").val(ui.item.value);
                    $("#txtlabel").text(ui.item.label);
                }
            }
        });
    });
</script>
<div class="ui-widget">
    <label id="txtlabel" style="color:Red"></label><br />
        Find by name: @Html.TextBox("SearchString")   
        <input type="submit" value="Search" />
 </div>
 public ActionResult AutocompleteSuggestions(string term)
{
  var suggestions = db.Students.Select(s => new { label = s.LastName+"|"+s.FirstMidName, value = s.StudentID}).Where(b=>b.label.ToLower().StartsWith(term.ToLower()));
  return Json(suggestions, JsonRequestBehavior.AllowGet);
}

 

posted @ 2013-07-25 16:38  James·wang  阅读(789)  评论(0)    收藏  举报