The following is my Data Table from which I will show the records.
![]()
Image 1
Open Visual Studio and go to "File" -> "New" -> "Project..." and you will get the New Project window as in the following:
![]()
Image 2
![]()
Image 3
We will now add our Data Table. So right-click on the Models folder then select "Add" -> "ADO.NET Entity Data Model".
![]()
Image 4
Give it a name.
![]()
Image 5
![]()
Image 6
![]()
Image 7
![]()
Image 8
![]()
Image 9
![]()
Image 10
Now it is time to add the Web API. So Right-click on Controller -> Add -> Controller.
![]()
Image 11
Select API Controller with read/write actions, using Entity Framework from the Template, select Model Class and select Data Context Class then click Add.
![]()
Image 12
This StudentAPI controller will generate code for Get, Put, Post & Delete methods. Here I modify my Get method since I need to pass my search text.
Here we need only a Get method.
The following is my StudentAPIController class:
Now add a controller. Right-click on the Controller folder then select Add -> Controller.
![]()
Image 13
Now add a View. So right-click on the Index Method then select Add View.
![]()
Image 14
![]()
Image 15
Make sure your solution has the following JavaScript and CSS files. Otherwise you can download these from the jQuery site.
jquery-1.8.2.js
jquery-ui-1.9.0.js
& jquery-ui-1.9.0.custom.css
Now our Index.cshtml is:
- @{  
-     ViewBag.Title = "jQuery AutoComplete Text Box using WEB API";  
-       
- }  
-   
- <link href="~/CSS/jquery-ui-1.9.0.custom.css" rel="stylesheet" />  
- <script src="~/Scripts/jquery-1.8.2.js"></script>  
- <script src="~/Scripts/jquery-ui-1.9.0.min.js"></script>  
- <style>  
-     .ui-autocomplete {  
-         max-height: 100px;  
-         overflow-y: auto;  
-     }  
-   
-     .ui-autocomplete {  
-         height: 100px;  
-     }  
- </style>  
- <div id="body">  
-     <table style="background-color: skyblue; border: solid 4px green; width: 80%; text-align: center;">  
-         <tr>  
-             <td>  
-                 <label for="autocomplete-textbox">Enter User Name : </label>  
-             </td>  
-             <td style="text-align: left">  
-                 <input type="text" id="txtName" /></td>  
-         </tr>  
-         <tr>  
-             <td></td>  
-         </tr>  
-         <tr>  
-             <td>  
-                 <label id="lblMessage" style="color: red;"></label>  
-             </td>  
-             <td style="text-align: left">  
-                 <label id="lblSelectedVal" style="color: magenta;"></label>  
-             </td>  
-         </tr>  
-     </table>  
- </div>  
-   
- <script type="text/javascript">  
-     $(document).ready(function () {  
-         $('#txtName').autocomplete({  
-             source: function (request, response) {  
-                 var autocompleteUrl = '/api/StudentAPI' + '?searchText=' + request.term;  
-                 $.ajax({  
-                     url: autocompleteUrl,  
-                     type: 'GET',  
-                     cache: false,  
-                     dataType: 'json',  
-                     success: function (json) {  
-                         response($.map(json, function (data, id) {  
-                             return {  
-                                 label: data.Name,  
-                                 value: data.Name  
-                             };  
-                         }));  
-                     },  
-                     error: function (xmlHttpRequest, textStatus, errorThrown) {  
-                         console.log('some error occured', textStatus, errorThrown);  
-                     }  
-                 });  
-             },  
-             minLength: 1,  
-             select: function (event, ui) {  
-                 lblMessage.innerText = "Your Selected Name :";  
-                 lblSelectedVal.innerText = ui.item.label;  
-                 $('#txtName').val(ui.item.label);  
-                 return false;  
-             }  
-         });  
-     });  
- </script>  
 
 
Run the application.
![]()
Image 16
![]()
Image 17
![]()
Image 18
![]()
Image 19