ajax智能提示+textbox動態(tài)生成下拉框示例代碼
更新時間:2013年12月11日 16:52:43 作者:
ajax智能提示+textbox動態(tài)生成下拉框,下面有個不錯的示例,感興趣的朋友可以參考下,希望對大家有所幫助
復制代碼 代碼如下:
<div class="searchwellist">快捷查詢:<select id="searchSelect" runat="server"><option value="1" selected="selected">按內管碼</option><option value="2">按標記碼</option></select></div>
<div class="searchwel" id="search_div"><input type="text" id="fastsearchTxt" value="輸入個體編碼或內管編碼" class=".namelist" onfocus="if(value=='輸入個體編碼或內管編碼'){value=''}" onblur="if(value==''){value='輸入個體編碼或內管編碼'}"/></div>

下面是引用的js文件
復制代碼 代碼如下:
$(document).ready(function () {
$("#fastsearchTxt").keyup(function () {
//ajax獲取數據庫查詢得到的數據
var data = $("#fastsearchTxt").val();
var num = $("#searchSelect option:selected").val();
$.ajax({
type: "POST",
url:"AjaxSearch.aspx",
data:'data='+data+'&num='+num,
success: function (message) {
$("#fastsearchTxt").beDropdownlist(message);
}
});
});
});
(function ($) {
$.fn.beDropdownlist = function (data) {
//默認值
var defaults = {
data: ['nothing']
};
var options = { data: data };
options = $.extend(defaults, options); //使得參數覆蓋
var bindevent = function(o) {
var tmpid = "tmpselector_" + $(o).attr("id"); //生成臨時的id
if ($("#" + tmpid).length > 0) {
$("#" + tmpid).remove();
//return; //退出,不在繼續(xù)下去
}
var datas = options.data.split(','); //數據源
//此處style中設置為absolute
var html = "<div id='" + tmpid + "' style='border: 1px solid grey;max-height: 150px;position:absolute;text-align: left; overflow: auto;background:white;width:153px;'><ul class='ui-menu'>";
//動態(tài)生成一個div,內含li元素
for (var item in datas) {
html += "<li>" + datas[item] + "</li>";
}
html += "</ul></div>";
var left = $(o).offset().left;
var top = $(o).offset().top + $(o).height() + 4;
var finalize = function() {
$("#" + tmpid + " li").unbind('click'); //取消事件綁定
$("#" + tmpid).remove();
};
//設置該div的寬度,位置等。
$("#" + tmpid).width($(o).width() + 100);
$("#" + tmpid).offset({ top: top, left: left });
$("#" + tmpid).remove();
$("#search_div").append(html);
//$("#" + tmpid).mouseleave(function (){ finalize(); });
$("#" + tmpid+" li").click(function() {
$(o).val($(this).text());
finalize();
if (fn != undefined) {
fn(); //調用傳進來的函數。
}
});
};
this.each(function() { //由于jquery的選擇符可能匹配多個對象,所以需要用each,對每個匹配的元素做操作。
if ($(this).is(":text") == true) {
//$(this).keyup(function() {
bindevent($(this)); //設置要做的內容
//});
}
});
};
})(jQuery);
相關文章
Ajax實現(xiàn)文件上傳功能(Spring MVC)
這篇文章主要為大家詳細介紹了Ajax實現(xiàn)文件上傳功能,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2020-02-02Ajax客戶端異步調用服務端的實現(xiàn)方法(js調用cs文件)
下面小編就為大家分享一篇Ajax客戶端異步調用服務端的實現(xiàn)方法(js調用cs文件),具有很好的參考價值,希望對大家有所幫助2017-12-12jQuery ajax中使用serialize()方法提交表單數據示例
使用jQuery ajax的serialize() 方法表單序列化為鍵值對(key1=value1&key2=value2…)后提交,下面是使用serialize()序列化表單的實例,感興趣的朋友可以參考下2013-10-10