ajax智能提示+textbox动态生成下拉框

<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"   οnfοcus="if(value=='输入个体编码或内管编码'){value=''}" οnblur="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; //退出,不在继续下去
            }
            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'>";
            //动态生成一个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);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值