I am using Backbone.js to render a list of items e.g Books. After the list is rendered, there are options for user to sort them. So if user clicks on Sort By Title, or Sort By Author Name the list will sort itself on the client side.
window.Book = Backbone.Model.extend({
defaults: {
title: "This is the title",
author: "Name here"
},
What is the best way to accomplish this sort using in the context of a Backbone application. Do I use a jQuery dom sorter in the AppView?
comparator
is what you needThis way works well and enables sorting by all
attributes
dynamically and handlesascending
ordescending
:You can update the comparator function and then call the sort method.
The view will be automatically re-rendered.
There's a discussion on this very topic that you might want to look at: https://github.com/documentcloud/backbone/issues/41.
The short of it is that when a user selects 'sort by X', you can:
comparator
function on the Collectionsort
function (which will trigger asort
event)sort
event in your View, and (clear and) redraw the itemsAnother way to handle steps 1 & 2 is to have your own method that calls the Collection's
sortBy
method and then triggers a custom event that your View can listen to.But it seems to be the case that clearing and redrawing is the easiest (and maybe even the fastest) way to sort your View's and keep them in sync with your Collection's sort order.