[英]How do I implement autocomplete textbox using asp.net mvc, javascript,cache, ajax
我需要實現自動完成文本框,使用Asp.Net MVC3,而不是jQuery,使用JavaScript從數據庫(服務器)獲取值。 因此,請嘗試幫助我提供源代碼。
我正在使用ASP.Net MVC3。
為此,存在jQuery自動完成功能。 http://docs.jquery.com/Plugins/Autocomplete您需要做的就是編寫一個jquery代碼。 假設這是您查看頁面中的文本框。
<輸入type =“ text” id =“ AutoComplete” value =“” />
為此文本框編寫一個jQuery。
$(document).ready(function () {
$("#AutoComplete").keypress(function () {
var title = $("#AutoComplete").val();
var availableTags = [];
if (title.length == 3) {
$.get("/Wk/GetTitle/" + title, function (data) {
var arr = jQuery.makeArray(data.split(','));
for (var i = 0; i < arr.length; i++) {
availableTags.push(arr[i]);
}
$("#AutoComplete").autocomplete({
source: availableTags
});
// $(“#AutoComplete”)。select(); });
}
});
});
這將使用ajax調用action方法,並且該action方法返回要顯示的列表。 這里獲得標題是動作方法。 控制器動作代碼是
[HttpGet]
public StringBuilder GetTitle(string inputString)
{
StringBuilder sb = new StringBuilder();
List<string> title = new List<string>();
int i = 0;
string slug = RouteData.Values.Values.ElementAt(2).ToString();
title = pageBL.GetTitleAutocomplete(slug);
for (i = 0; i <= title.Count - 1; i++)
{
if (i != title.Count -1 )
sb = sb.Append(title.ElementAt(i) + ",");
else
sb = sb.Append(title.ElementAt(i) );
}
return sb;
}
此代碼將幫助您問我是否有問題
鑒於:-
<input type="text" id="txtRemark" name="txtRemark" class="form-control" placeholder="Remark">
<link rel="stylesheet" href="//code.jquery.com/ui/1.11.4/themes/smoothness/jquery-ui.css">
<script src="//code.jquery.com/ui/1.11.4/jquery-ui.js"></script>
<script>
$(document).ready(function () {
$("#txtRemark").autocomplete({
source: function (request, response) {
$.ajax({
url: "/ControllerName/AutoCompleteRemark",
type: "POST",
dataType: "json",
data: { remark: request.term },
success: function (data) {
response($.map(data, function (item) {
return { label: item.VCEHRemark, value: item.VCEHRemark };
}))
}
})
},
messages: {
noResults: "", results: ""
}
});
})
在控制器中:
public JsonResult AutoCompleteRemark(string remark)
{
var result = db.tablename.Where(p => p.VCEHRemark.Contains(remark)).Select(p => new { p.VCEHRemark });
return Json(result, JsonRequestBehavior.AllowGet);
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.