93 votes

Comment passer des paramètres à une vue

J'ai une série de boutons qui, lorsqu'on clique dessus, affichent un menu contextuel placé juste en dessous du bouton. Je veux transmettre la position du bouton à la vue. Comment puis-je le faire ?

ItemView = Backbone.View.extend({
    tagName: 'li',
    events: {
        'click': 'showMenu'
    },
    initialize: function() {
        _.bindAll(this, 'render');
    },
    render: function() {
    return $(this.el).html(this.model.get('name'));
    },
    showMenu: function() {
        var itemColl = new ItemColl();
        new MenuView({collection: itemColl}); // how to pass the position of menu here?
    }
});

167voto

dira Points 3498

Il vous suffit de passer le paramètre supplémentaire lorsque vous construisez le MenuView. Il n'est pas nécessaire d'ajouter le paramètre initialize fonction.

new MenuView({
  collection: itemColl,
  position: this.getPosition()
})

Et puis, en MenuView vous pouvez utiliser this.options.position .

UPDATE : Comme @mu est un état trop court depuis la version 1.1.0, Backbone Views n'attache plus automatiquement les options passées au constructeur comme this.options, mais vous pouvez le faire vous-même si vous préférez.

Donc, dans votre initialize vous pouvez enregistrer la méthode options passé en tant que this.options :

initialize: function(options) {
    this.options = options;
    _.bindAll(this, 'render');
},

ou utiliser des moyens plus fins comme décrit par @Brave Dave .

46voto

mu is too short Points 205090

Ajouter un argument d'options à initialize :

initialize: function(options) {
    // Deal with default options and then look at options.pos
    // ...
},

Et ensuite passer dans certaines options lorsque vous créez votre vue :

var v = new ItemView({ pos: whatever_it_is});

Pour plus d'informations : http://backbonejs.org/#View-constructor

12voto

Brave Dave Points 802

À partir de la version 1.1.0 du backbone, l'option options L'argument est ne sont plus attachés automatiquement à la vue (voir numéro 2458 pour la discussion). Vous devez maintenant attacher les options de chaque vue manuellement :

MenuView = Backbone.View.extend({
    initialize: function(options) {
        _.extend(this, _.pick(options, "position", ...));
    }
});

new MenuView({
    collection: itemColl,
    position: this.getPosition(),
    ...
});

Vous pouvez également utiliser ce mini plugin pour attacher automatiquement les options de la liste blanche, comme ceci :

MenuView = Backbone.View.extend({
    options : ["position", ...] // options.position will be copied to this.position
});

-1voto

Imtiaz Mirza Points 91

Passe d'un autre endroit

 new MenuView({
   collection: itemColl,
   position: this.getPosition()
})

Ajoutez un argument d'options pour initialiser en vue que vous obteniez cette variable passée,

initialize: function(options) {
   // Deal with default options and then look at options.pos
   // ...
},

pour obtenir la valeur utiliser -

   var v = new ItemView({ pos: this.options.positions});

-2voto

Nishant Points 1605

Utilisez ce.options pour récupérer l'argumentr dans la vue

 // Place holder
 <div class="contentName"></div>

 var showNameView = Backbone.View.extend({
        el:'.contentName',
        initialize: function(){
            // Get name value by this.options.name
            this.render(this.options.name);
        },
        render: function(name){
            $('.contentName').html(name);
        }
    });

    $(document).ready(function(){
        // Passing name as argument to view
        var myName1 = new showNameView({name: 'Nishant'});
    });

Exemple de travail : http://jsfiddle.net/Cpn3g/1771/

Prograide.com

Prograide est une communauté de développeurs qui cherche à élargir la connaissance de la programmation au-delà de l'anglais.
Pour cela nous avons les plus grands doutes résolus en français et vous pouvez aussi poser vos propres questions ou résoudre celles des autres.

Powered by:

X