Drag and drop features can dramatically improve the UX of a web application. Implementing drag and drop with Javascript seems intimidating, which is why we have the Angular CDK (Component Development Kit).
Let’s say we have a list of items we want to be able to reorder using drag and drop:
data:image/s3,"s3://crabby-images/9c548/9c548cf1af777e75a498f4fa0ba1794486bf90fa" alt=""
Thanks to the CDK drag-and-drop directives, such a task is easy. Here’s all the code needed to enable it:
data:image/s3,"s3://crabby-images/8d7ea/8d7eafb6384631fe96bd8d78c7403cfc67429df1" alt=""
The two directives cdkDropList
and cdkDrag
enable the drag-and-drop feature. We also need the following code in our component class:
data:image/s3,"s3://crabby-images/0482c/0482cd9bca883a7cc1d37e6e72906a806799648e" alt=""
The moveItemInArray
function is a utility function from the CDK, so we don’t have to worry about that.
See the source code and try this example in action on Stackblitz here.