3

I have a textbox with ajax jquery autocomplete feature.but the textchange event is not firing.

<asp:TextBox ID="txtNumber" runat="server" width="98%" OnTextChanged="txtNumber_TextChanged" AutoPostBack="true" ></asp:TextBox>

Autocomplete function:

 function QuoteNumber(sender, args) {
        $(function () {
            $("#<%=txtNumber.ClientID %>").autocomplete({
                source: function (request, response) {
                    $.ajax({
                        url: '<%=ResolveUrl("~/Webservice.asmx/GetNumberForAutocomplete") %>',
                        data: "{ 'prefix': '" + request.term + "'}",
                        dataType: "json",
                        type: "POST",
                        async: false,
                        mustMatch: true,
                        contentType: "application/json; charset=utf-8",
                        success: function (data) {
                            response($.map(data.d, function (item) {
                                return {
                                    label: item.split('^')[0],
                                    val: item.split('^')[1]
                                }
                            }))
                        },
                        error: function (response) {

                        },
                        failure: function (response) {

                        }
                    });
                },
                select: function (e, i) {
                    $("#<%=hdnNumber.ClientID %>").val(i.item.val);
                    if (i.item.val == "No Records Found") {
                        $("#<%=hdnNumber.ClientID %>").val(-1);
                        document.getElementById('<%=txtNumber.ClientID%>').value = "";
                        return false;
                    }

                },
                minLength: 0
            }).bind('focus', function () { $(this).autocomplete("search"); });
        });
    }
sona
  • 1,552
  • 3
  • 18
  • 37

3 Answers3

1
<script type="text/javascript">
$(document).ready(function () {
    $("#<%=txtSearch.ClientID %>").autocomplete({
        source: function (request, response) {
            $.ajax({
                url: '<%=ResolveUrl("~/Service.asmx/GetCustomers") %>',
                data: "{ 'prefix': '" + request.term + "'}",
                dataType: "json",
                type: "POST",
                contentType: "application/json; charset=utf-8",
                success: function (data) {
                    response($.map(data.d, function (item) {
                        return {
                            label: item.split('-')[0],
                            val: item.split('-')[1]
                        }
                    }))
                },
                error: function (response) {
                    alert(response.responseText);
                },
                failure: function (response) {
                    alert(response.responseText);
                }
            });
        },
        select: function (e, i) {
            $("#<%=hfCustomerId.ClientID %>").val(i.item.val);
            $("#<%=hfCustomerName.ClientID %>").val(i.item.value);
            $("[id*=btnSubmit]").click();
        },
        minLength: 1
    });

});

Sumanta
  • 313
  • 2
  • 6
  • 17
1

Add to end of select callback this line: __doPostBack('<%= txtNumber.UniqueID %>', '');

Yuriy Rozhovetskiy
  • 22,270
  • 4
  • 37
  • 68
0

In addition to above answer we need to below code snippest in Select:

select: function (e, i) {
        $("#<%=hfCustomerId.ClientID %>").val(i.item.val);
        $("#<%=hfCustomerName.ClientID %>").val(i.item.value);
        $("[id*=btnSubmit]").click();
       $("#<%=txtNumber.ClientID %>").val(i.item.value);
      __doPostBack('<%= txtNumber.UniqueID %>', '');
    },