2011-09-25 16 views
11

Bien, entonces he leído varias otras preguntas con respecto a las vistas de la red troncal y los eventos que no se activan, sin embargo, todavía no lo estoy recibiendo con tristeza. He estado jugando con Backbone por alrededor de un día, así que estoy seguro de que me estoy perdiendo algo básico. He aquí una jsFiddle con lo que estoy trabajando con: http://jsfiddle.net/siyegen/e7sNN/3/backbone.js events y el

(function($) { 

    var GridView = Backbone.View.extend({ 
     tagName: 'div', 
     className: 'grid-view', 
     initialize: function() { 
      _.bindAll(this, 'render', 'okay'); 
     }, 
     events: { 
      'click .grid-view': 'okay' 
     }, 
     okay: function() { 
      alert('moo'); 
     }, 
     render: function() { 
      $(this.el).text('Some Cow'); 
      return this; 
     } 
    }); 

    var AppView = Backbone.View.extend({ 
     el: $('body'), 
     initialize: function() { 
      _.bindAll(this, 'render', 'buildGrid'); 
      this.render(); 
     }, 
     events: { 
      'click button#buildGrid': 'buildGrid' 
     }, 
     render: function() { 
      $(this.el).append($('<div>').addClass('gridApp')); 
      $(this.el).append('<button id="buildGrid">Build</button>'); 
     }, 
     buildGrid: function() { 
      var gridView = new GridView(); 
      this.$('.gridApp').html(gridView.render().el); 
     } 

    }); 

    var appView = new AppView(); 

})(jQuery); 

El okay evento en el GridView no se dispara, estoy asumiendo porque div.grid-view no existe cuando el evento se une primero. ¿Cómo debo manejar el enlace y la activación de un evento que se basa dinámicamente en una vista? (Además, es un ejemplo corto, pero no dude en gritar a mí si estoy haciendo cualquier otra cosa que no debería)

+0

porque 'el' es la etiqueta div con'-view' .grid. y estás encontrando el elemento de nombre de clase '.grid-view' en ese div. que no lo obtendrás – Mahi

Respuesta

21

Su problema es que los eventos en GridView:

events: { 
    'click .grid-view': 'okay' 
} 

dicen:

cuando se hace clic en un descendienteque coincide con '.grid-view', llame okay

se vinculen con este snippet from backbone.js:

if (selector === '') { 
    this.$el.on(eventName, method); 
} else { 
    this.$el.on(eventName, selector, method); 
} 

Así el elemento .grid-view tiene que estar contenida en la GridView de this.el y su this.el es <div class="grid-view">. Si cambia de events a esto:

events: { 
    'click': 'okay' 
} 

oirá sus vacas (o "oye en su mente" después de leer la alerta dependiendo de cómo está loco este problema se ha hecho).

violín fijo: http://jsfiddle.net/ambiguous/5dhDW/

+0

Eso funcionó, gracias. En general, si quiero vincular un evento al elemento que está creando la vista, ¿omitiría el selector? Lo probé y funciona con otra vista, solo asegurándome de que esa es la manera correcta de hacer las cosas. – siyegen

+0

@siyegen: Correcto. Eche un vistazo a la primera rama del fragmento 'backbone.js' que incluí; si no hay selector, entonces el evento está ligado directamente a 'this.el' usando' $ (this.el) .bind (eventName, method); ', si hay un selector, entonces el evento está vinculado con' delegate' . –

+0

pero, ¿qué sucede cuando deseo disparar el evento solo cuando 'this.el' tiene la clase' grid-view'? – Jashwant