In this post Asp.Net jQuery
UI Autocomplete with Asp.net Web Service returning custom class Object we shall see on how populate a jQuery Autocomplete control
using server side data exposed by an Asp.net web service, where the web service
returns a list of Custom objects
In this
example, the data will be initially loaded by calling the Asp.Net web service, also
the subsequent filters will be done in the server side, the letters types by
the user will be sent to the web-method and the filtering will happen at the
server side. 
Create an .aspx page, add a TextBox to the page and add the below jQuery script. Change the references of the jQuery library files to map to your local path.
Create an asp.net web service, add the web-method to the service, make sure that you change the name of the web-method in the jQuery script to call your web-method.
Create an .aspx page, add a TextBox to the page and add the below jQuery script. Change the references of the jQuery library files to map to your local path.
Create an asp.net web service, add the web-method to the service, make sure that you change the name of the web-method in the jQuery script to call your web-method.
Build and run the application. Notice
that the Autocomplete options are displayed using data returned from the web
service.
.Aspx page
.Aspx page
<html xmlns="http://www.w3.org/1999/xhtml">
<head runat="server">
    <title>jQuery UI Autocomplete </title>
    <link type="text/css"
href="css/smoothness/jquery-ui-1.8.21.custom.css"
rel="Stylesheet" />
    <script
type="text/javascript"
src="JavaScript/jquery-1.7.2.js"></script>
    <script
type="text/javascript"
src="JavaScript/jquery-ui-1.8.21.custom.min.js"></script>
    <link
type="text/css"
href="Stylesheet.css" // Add your own .css file (Optional)
rel="Stylesheet" />
<script type="text/javascript">
$(document).ready(function() {
//
            //
AutoComplete Server Data, Server Filter (Object)
            $("#txtAutocompleteServerObject").autocomplete
            ({
                source: function(request, response) {
                    $.ajax({
                        type: "POST",
                        url: "CountriesWebService.asmx/GetCountryObjectList",
                        dataType: "json",
                        data: "{ 'filterKey': '" + request.term + "' }",
                        contentType: "application/json; charset=utf-8",
                        dataFilter: function(data) { return
data; },
                        success: function(data) {
                           
response($.map(data.d, function(item) {
                            return { value: item.CountryCode }
                            }))
                        },
                        error: function(XMLHttpRequest, textStatus, errorThrown) {
                            var errorMessage = "Ajax
error: " + this.url + " : " + textStatus + " : " + errorThrown + " : " + XMLHttpRequest.statusText + " : " + XMLHttpRequest.status;
                            if
(XMLHttpRequest.status != "0" ||
errorThrown != "abort") {
                               
alert(errorMessage);
                            }
                        }
                    });
                },
                delay: 100
            });
});
</script>
</script>
</head>
<body>
    <form id=" frmAutocomplete" runat="server">
        <table>
            <tr>
  <td>Autocomplete
Server Source, Server Filter (Object): 
</td>
</td>
                <td>
                    <asp:TextBox 
                        ID="txtAutocompleteServerObject"
                        runat="server"></asp:TextBox>
                </td>                
            </tr>                                                                                                 
  </table>
    </form>
</body>
</html>
Web Service
namespace jQuery
namespace jQuery
{
    [WebService(Namespace
= "http://tempuri.org/")]
    [WebServiceBinding(ConformsTo
= WsiProfiles.BasicProfile1_1)]
    [System.ComponentModel.ToolboxItem(false)]
    // To allow this
Web Service to be called from script, using ASP.NET 
AJAX, uncomment the following line.
AJAX, uncomment the following line.
    [System.Web.Script.Services.ScriptService]
    public class CountriesWebService
: System.Web.Services.WebService
    {
        //
        [WebMethod]
        public List<clsCountry>
GetCountryObjectList(string filterKey)
        {
            List<clsCountry> lstCountry = new List<clsCountry>();
            string
strCountryList = string.Empty;
            //
            lstCountry.Add(new clsCountry("A1", "Albania"));
            lstCountry.Add(new clsCountry("A2", "Algeria"));
            lstCountry.Add(new clsCountry("A3", "Andorra"));
            lstCountry.Add(new clsCountry("A4", "Angola"));
            lstCountry.Add(new clsCountry("A5", "Anguilla"));
            lstCountry.Add(new clsCountry("A6", "Antarctica"));
            lstCountry.Add(new clsCountry("A7", "Argentina"));
            lstCountry.Add(new clsCountry("A8", "Armenia"));
            lstCountry.Add(new clsCountry("A9", "Aruba"));
            lstCountry.Add(new clsCountry("B1", "Belgium"));
            lstCountry.Add(new clsCountry("B2", "Belize"));
            lstCountry.Add(new clsCountry("B3", "Bermuda"));
            lstCountry.Add(new clsCountry("B4", "Bolivia"));
            lstCountry.Add(new clsCountry("B5", "Botswana"));
            lstCountry.Add(new clsCountry("B6", "Brazil"));
            lstCountry.Add(new clsCountry("B7", "Burundi"));
            lstCountry.Add(new clsCountry("B8", "Burkina"));
            //
            var
filteredCountries = from c in lstCountry
                                    where c.CountryName.StartsWith(filterKey)
                                    select c;
            //
            return
filteredCountries.ToList();
        }
    }
}
//
//
    public class clsCountry
    {
        public string _CountryCode;
        public string _CountryName;
        //
        public
clsCountry(string strCode, string strName)
        {
            this._CountryCode
= strCode;
            this._CountryName
= strName;
        }
        //
        public string CountryCode
        {
            get
{ return _CountryCode; }
            set
{ _CountryCode = value; }
        }
        //
        public string CountryName
        {
            get
{ return _CountryName; }
            set
{ _CountryName = value; }
        }
    }
}
For a
full example covering all possible scenarios in using a jQuery UI Autocomplete
control refer to the post Asp.net
jQuery UI Autocomplete Tutorial
Related Posts
 
No comments:
Post a Comment