Stickit动态绑定新创建的选择元素

时间:2015-06-16 07:09:35

标签: jquery marionette jquery-select2 backbone-stickit

在我的项目中,我使用带有stickit的Marionette进行双向数据绑定。

在那里我需要克隆具有select和textbox的div元素。

var $template = $('#template-clone');
var $clone = $template.clone();
$clone.show();

var observeSelectID = $clone.find('select').attr('id');
var selectID = '#'+observeSelectID; 

之后我尝试使用stickit绑定新创建的元素。

this.addBinding(null, {
    selectID : {
        observe : observeSelectID,
        initialize : function($el) {
            $(selectID).select2({
            });
        },
    },
    selectOptions : {
        collection : function(data) {
            var option = "{Label value pair JSON String}"   
            return {
                'opt_labels' : ['List'],
                'List' : option
            };
        }
    }
}); 

但是选择框中的任何更改都不会触发模型更改。

1 个答案:

答案 0 :(得分:0)

得到了解决方案: 为select2 stickit添加处理程序。

Backbone.Stickit.addHandler({
        selector : 'select.select2',
        initialize : function($el, model, opt) {
            var e = 'change:' + opt.observe,
                self = this;
            $el.select2();
            var up = function(m, v, o) {
                if (!o.stickitChange)
                    $el.trigger("change");
            };
            this.listenTo(model, e, up);
            this.listenTo(model, 'stickit:unstuck', function() {
                self.stopListening(model, e, up);
            });
        }
    });

并且在创建新元素时添加其绑定

            var textareaObserve = $('#textarea').attr('id');
            var textareaID = '#' + textareaObserve;

            self.bindings[selectedID] = observeSelectID;
            self.addBinding(self.model, selectedID, observeSelectID);

将进行select2绑定。