I'm new in backbone.js. And I see that in Backbone.js, the events binding :
var PersonView = Backbone.View.extend({
....
events : {
"click button.btnSay" : "saySomething"
},
saySomething : function(){
....
}
...
});
...doesn't need the button.btnSay to be existed in the time of calling, that's so similar to "delegate" in Jquery.
And now, the problem is, we can change any button in our html page to .btnSay (by Firebug, etc.). And they eventualy get the listeners. How can we prevent this?
It isn't similar to
delegate
it does usedelegate
(unless the event doesn't have a selector). The event binding in Backbone looks like this:So it uses
delegate
on the view's element. That at least limits the events to elements within the view.You can't stop people from messing around with your elements and events in a debugger. They can change the HTML, the CSS, and even edit your JavaScript so you can't stop them from causing trouble on your page. You can stop them from making a mess on your server though, just don't trust anything that Backbone sends to your server and validate everything the same way you would validate anything else that comes in from the outside world.
Basically, don't waste your time worrying about someone smashing their own face with a brick by messing with your HTML/events/JavaScript. Let them hurt themselves all they want. But do protect your server by not trusting anything from the outside world (and your servers shouldn't even trust themselves any more than they have to).
Under the hood, Backbone uses jQuery's "delegate" to wire up the events. So it's not that this is "like" jQuery, it is jQuery doing it for us.
To prevent scoping problems and ensure that our View events are only working with the HTML/DOM elements that we want, all
events
declarations are scoped to the View'sel
.When a Backbone view is instantiated, an
el
attribute is either generated for you, or assigned by you. This gives you the opportunity to either attach your view to an existing chunk of the DOM or to create a new chunk of HTML that can be attached to the DOM.Here's how you can attach to the existing DOM:
By specifying the
el
when we instantiate the view, or by specifying it directly in our view definition, we use an existing element.If we omit the
el
from the constructor options and from the view definition, Backbone will generate anel
for us. By default it will generate a div inel
when the view is instantiated.Once a View has it's
el
, whether through generation or assignment, the view's event declarations are delegated via jQuery, scoped to the view'sel
.let's say you have the following html:
with your example View, we could assign a view to either the
foo
or thebar
element, and only the button within that element would get the click event.Now when you click the button in the
foo
div, you'll get thesaySomething
callback fired. But because the events for PersonView were scoped within theel
for that instance of PersonView, clicking the button withinbar
will never fire the callback.