Backbone中添加了多个模态
我从DetailsView打开模态
如下:
var $ = jQuery = require('jquery'), Backbone = require('backbone'), Handlebars = require('handlebars'), _ = require('underscore'), skuDetailsTemplate = require("../../templates/sku/SkuDetails.html"), skuDetailsModel = require('../../models/sku/SkuDetailsModel'), updateSkuModel = require('../../models/sku/UpdateSkuModel'), skuUpdateView = require('../../views/sku/UpdateSkuView'), inventoryForFacilityModel = require('../../models/inventory/InventoryForFacilityModel'), skuListingModel = require('../../models/sku/listing/SkuListingModel'); var SkuDetailsView = Backbone.View.extend({ el: ".sku-details-container", tagName: "div", initialize: function (options) { var self = this; this.skuDetailsModel = new skuDetailsModel(); this.inventoryForFacilityModel = new inventoryForFacilityModel(); this.skuListingModel = new skuListingModel(); this.listenTo(self.skuDetailsModel, 'add', self.render); this.listenTo(self.skuDetailsModel, 'change', self.render); this.listenTo(self.inventoryForFacilityModel, 'add', self.render); this.listenTo(self.inventoryForFacilityModel, 'change', self.render); this.listenTo(self.skuListingModel, 'add', self.render); this.listenTo(self.skuListingModel, 'change', self.render); this.sku_id = options.sku_id; this.skuDetailsModel.set("id", this.sku_id); this.skuDetailsModel.fetch({}); this.inventoryForFacilityModel.set("id", this.sku_id); this.inventoryForFacilityModel.fetch({}) this.skuListingModel.set("id", this.sku_id); this.skuListingModel.fetch({}) }, events: { "click .openModal": "openUpdateModal", "click .btnEditSku": "openUpdateModal" }, openUpdateModal: function (ev) { var data = { model: this.skuDetailsModel }; var modalView = new skuUpdateView(data); modalView.show(); }, render: function () { var self = this; this.$el.html(skuDetailsTemplate({ skuDetails: self.skuDetailsModel.toJSON(), inventoryByFacility: self.inventoryForFacilityModel.toJSON(), skuListing: self.skuListingModel.toJSON() })); } }); module.exports = SkuDetailsView;
ModalView
var UpdateSkuView = Backbone.View.extend({ className: "modal fade", attributes: { tabindex: "-1", role: "dialog", }, initialize: function (options) { var self = this; this.model = options.model; this.updateSkuModel = new updateSkuModel(); this.template = skuUpdateTemplate; }, events: { "click .save": "saveHandler", "click .closeModal": "close", "change .clsEdit": "recordModelChange" }, recordModelChange: function (e) { var field = e.target.id; var value = e.target.value; var res = this.model.toJSON(); var obj = {}; // if (field === "length" || field === "width" || field === "height" || field === "weight" || field === "mrp" || field === "recommended_selling_price") { // value = parseFloat(value); // } obj[field] = value; obj["id"] = res.records[0].id; //var res = this.model.toJSON(); this.updateSkuModel.set(obj, { validate: true }); }, saveHandler: function (e) { //Save logic var self = this; e.preventDefault(); var options = { validate: true, success: function (model, response) { self.showSuccessMessage("SKU with id " + response.records[0].id + " updated successfully"); setTimeout(function () { self.close(); }, 1500); } }; this.updateSkuModel.save({}, options); }, render: function () { var self = this; this.$el.html(this.template({ skuDetails: self.model.toJSON() })).modal() return this; }, show: function () { $(document.body).append(this.render().el); }, close: function () { this.$el.remove(".modal fade"); this.$el.modal("hide"); this.$el.empty(); this.undelegateEvents(); } }); module.exports = UpdateSkuView;
如果我打开一个模态然后关闭它然后再打开模态的另一个实例它会超过前一个模态。
请帮忙。
我的问题:
Vini,你的模态视图从不调用从父视图或从它自身删除http://backbonejs.org/#View-remove 。
模态很难追踪。 正是因为这个原因,我使用了使用骨干的Rendering bootstrap模式
尽管如此! 看看你有的事件。 您重新渲染父视图,而不清除绑定或删除后续视图。
this.listenTo(self.skuDetailsModel, 'add', self.render); this.listenTo(self.skuDetailsModel, 'change', self.render); this.listenTo(self.inventoryForFacilityModel, 'add', self.render); this.listenTo(self.inventoryForFacilityModel, 'change', self.render); this.listenTo(self.skuListingModel, 'add', self.render); this.listenTo(self.skuListingModel, 'change', self.render);
我感觉到这个this.listenTo(self.skuListingModel, 'change', self.render);
每次重新渲染/更新“sku”时绑定“点击事件”删除它并查看它是否有效。
我使用一个modalManager类来扩展Backbone.View以用于显示模态视图。 我认为你的问题是关闭函数,你需要隐藏模态,然后像我的隐藏function一样删除它。
modalManager = Backbone.View.extend({ className: "modal", template: 'modals/modal.html', title: '', content: '', showButton: true, events: { 'click .close': 'hide', 'click .btn': 'hide' }, initialize: function (options) { _.extend(this, _.pick(options, "title")); _.extend(this, _.pick(options, "content")); this.render(); }, show: function () { this.$el.modal('show'); }, hide: function () { this.$el.modal('hide'); this.remove(); }, render: function () { this.$el.html(this.template({title: this.title, content: this.content, showButton: this.showButton})); }, setTitle: function(title) { this.title=title; this.render(); }, setContent: function(content) { this.content=content; this.render(); }, setShowButton: function(showbutton) { this.showButton=showbutton; this.render(); } })
你的近距离方法必须改变:
close: function () { this.undelegateEvents(); this.$el.remove(); this.remove(); }
由于你总是在创建一个新的模态,旧的模态是不必要的(垃圾)
您可以在此处创建模态实例:
var modalView = new skuUpdateView(data);
在这里你打开它。
modalView.show();
模态视图不能被垃圾收集,因为它是从另一个视图引用的。
您必须从引用它的视图中关闭模态
modalView.close();
解决了我的问题:
这是因为我有我的详细信息视图的多个实例,模式被渲染了很多次。
我做了什么来解决这个问题:
给我的DetailsView
一个独特的$el