Sortable JSP Tag Overview
The Sortable JSP tag is a server-side wrapper for the Kendo UI Sortable widget.
Getting Started
The Basics
Unlike most of the server-side wrappers, the Kendo UI Sortable does not render HTML markup. The Sortable should be initialized for already existing DOM element.
Configuration
Below are listed the steps for you to follow when configuring the Kendo UI Sortable.
Step 1 Make sure you followed all the steps from the introductory article on Telerik UI for JSP.
Step 2 Create a new action method to render the view.
@RequestMapping(value = {"index"}, method = RequestMethod.GET)
public String index() {
return "web/sortable/index";
}
Step 3 Add kendo taglib mapping to the page.
<%@taglib prefix="kendo" uri="https://www.telerik.com/kendo-ui/jsp/tags"%>
Step 4 Add a sortable tag (use the element with sortable-basic
id and initialize Sortable instance for it).
<kendo:sortable name="#sortable-basic" hint="hint" placeholder="placeholder">
</kendo:sortable>
Step 5 Add the HTML markup from which the widget will be initialized and define the hint/placeholder functions.
<ul id="sortable-basic">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
<script>
function hint(element) {
return element.clone().addClass("hint");
}
function placeholder(element) {
return element.clone().addClass("placeholder").text("drop here");
}
</script>
Hint Disabling
The Kendo UI Sortable widget can operate without a hint. To disable the hint, set it to an empty function via jQuery.noop
.
<kendo:sortable name="#sortable-basic" hint="noHint">
</kendo:sortable>
<script>
var noHint = $.noop;
</script>
Event Handling
Subscribe to Events
You can subscribe to all events exposed by Kendo UI Sortable by the handler name.
<kendo:sortable name="#sortable-basic" start="onStart" change="onChange">
</kendo:sortable>
<ul id="sortable-basic">
<li>Item 1</li>
<li>Item 2</li>
<li>Item 3</li>
</ul>
<script>
function onStart(e) {
//handle event
}
function onChange(e) {
//handle event
}
</script>
Reference
Existing Instances
You are able to reference an existing Sortable instance via jQuery.data()
. Once a reference is established, you are able to use the Sortable API to control its behavior.
// Put this after your Kendo Sortable tag declaration
<script>
$(function() {
// Notice that the name attribute of the sortable is used to get its client-side instance
var sortable = $("#sortable-basic").data("kendoSortable");
});
</script>