Ajax Binding

Getting Started

When configured for Ajax binding, the Kendo UI AutoComplete for JSP makes Ajax requests when doing filtering.

Configuration

To configure the Kendo UI AutoComplete for Ajax binding, follow the steps below (using the Spring MVC framework).

Step 1 Add a new action method which will return data to populate the AutoComplete.

    @Autowired
    private ProductDao product;

    @RequestMapping(value = "/remote-data/read", method = RequestMethod.POST)
    public @ResponseBody DataSourceResult read() {

    }

Step 2 Add a new parameter, which is to be populated with the current AutoComplete request information—filter.

    @RequestMapping(value = "/remote-data/read", method = RequestMethod.POST)
    public @ResponseBody DataSourceResult read(@RequestBody DataSourceRequest request) {

    }

Step 3 Use the request information to process the data and return the result as JSON.

    @RequestMapping(value = "/remote-data/read", method = RequestMethod.POST)
    public @ResponseBody DataSourceResult read(@RequestBody DataSourceRequest request) {

        return product.getList(request);
    }

The result format in this case is similar to the signature, demonstrated in the example below.

    public class DataSourceResult {
        public long getTotal() {
            //..
        }

        public void setTotal(long total) {
            //..
        }

        public List<?> getData() {
            //..
        }

        public void setData(List<?> data) {
            //..
        }

        public Map<String, Object> getAggregates() {
            //..
        }

        public void setAggregates(Map<String, Object> aggregates) {
            //.
        }
    }

Step 4 In the view, configure the AutoComplete to use the action method created in the previous steps.

    <c:url value="/web/autocomplete/remote-data/read" var="readUrl" />

    <kendo:autoComplete name="products" dataTextField="productName">
        <kendo:dataSource serverFiltering="true">
            <kendo:dataSource-transport>
               <kendo:dataSource-transport-read url="${readUrl}" type="POST" contentType="application/json"/>
            </kendo:dataSource-transport>
            <kendo:dataSource-schema data="data" total="total">
            </kendo:dataSource-schema>
        </kendo:dataSource>
    </kendo:autoComplete>

Client Data Processing

In the configuration that enables client data processing during Ajax binding, Kendo UI AutoComplete for JSP requests data from the server every time the user types in the widget. This behavior can be changed by setting the DataSource server operation options to false.

   <kendo:dataSource serverFiltering="false">
       <kendo:dataSource-transport>
           <kendo:dataSource-transport-read url="${readUrl}"/>
       </kendo:dataSource-transport>
   </kendo:dataSource>

See Also

In this article