- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我们必须显示以下 View :
类别(显示为表格),每个类别表格应该有产品(tr)。
我们如何使用 Marionette itemView 和 CompositeView 构建它?
我们需要产品成为一个 itemView。
我们是否应该将每个类别都做成CompositeView,并且有多个CompositeView?或者是否有任何其他替代方法可以将所有 compositeViews 包含到一个项目中,例如:
Collection(CompositeView???)
-> CompositeView-category1
-> itemView-product1-1
-> itemView-product1-2
-> CompositeView-category2
-> itemView-product2-1
-> itemView-product2-2
最佳答案
我建议您使用布局 View ,在此布局中,您可以为每个类别设置一个区域,并在这些区域上绘制复合 View 。
marionette 中 Layout View 的好处是您可以传递一个模板,该模板应包含您最初需要的所有 HTML,例如带有按钮的标题以添加和删除类别等。
CategoriesLayout = Backbone.Marionette.Layout.extend({
template: "#layout-template",
regions: {
category1Region: "#category1",
category2Region: "#category2"
}
});;
and then you can render your composite views inside the regions
categoriesLayout = new CategoriesLayout();
categoriesLayout.category1Region.show(new CategoryView());
这样您就可以使用区域功能显示/关闭您的 View 。如果您需要动态添加区域,也可以使用 Marionette.renderer 呈现 HTML,然后将您的区域附加到布局。
此外,您可能想看看 Marionette 的区域管理器,它可以帮助您管理一组区域。
编辑
我做了一个 jsfiddle 来演示这一点,这只是一个例子,但我认为这个想法就在那里......
MyLayout = Backbone.Marionette.Layout.extend({
template: "#layout-template",
regions: {
menu: "#menu",
}
});
var layout = new MyLayout({el:"#container"});
layout.render();
var dynamicRegion = sampleModel.get('categoryName');
layout.addRegion(dynamicRegion,"#dynamic"); // adding the region on the fly
layout[dynamicRegion].show(sampleView); // using it!
所以在评论中回答你的问题
categoriesLayout[dynamicRegion].show(new CategoryView())
只需确保 DOM 元素存在(#dynamic),如果不存在,只需将 HTML 附加到您的布局 View 或使用 marionette.Renderer 对象为您的区域传递一个漂亮的模板。
动态添加区域没有问题,marionette 有一种方法可以应对这种情况。
希望对你有帮助,
关于collections - 如何使用多个同类 CompositeView 构建 Marionette?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20219675/
问题是,每次我通过每个元素上的集合 (MovieCollection) 的获取函数添加新对象时,都会添加某种事件触发器,并初始化一个新的 MovieList 集合在获取所有项目后传递到的对象。 这是我
我正在开发一个基本的调查应用程序来学习 Marionette/很好地掌握嵌套模型(答案 > 问题 > 调查)。我正在使用 backbone-relational 来完成这个。 在调查 View 中,我
我需要向 listView.template 传递一个值,以便了解有关 collection.length 的模板。 我认为一种选择是重新定义 serializeData 方法以便以这种方式传递参数。
我需要向 listView.template 传递一个值,以便了解有关 collection.length 的模板。 我认为一种选择是重新定义 serializeData 方法以便以这种方式传递参数。
简而言之,这就是我所需要的。 我需要显示一个下拉列表/组合框,其中的子项可以来自许多集合。所有这些集合的模型都有一个文本属性,我将在下拉列表中显示该属性。 我想知道是否可以从许多集合中创建下拉列表。
我希望我的合成自动呈现一个集合,它已经这样做了。不过,我也希望它能为我获取一个模型,并为该模型提供复合访问权限。 基本上,我正在尝试使用下面的一组客户呈现用户详细信息。 复合 View define(
我只需要渲染获取的集合的第一个元素。 ItemView = Backbone.Marionette.ItemView.extend({ template: "#item" }); Items
我正在尝试对 Marionette.CompositeView 中的集合进行排序。 我有一个看起来像这样的集合: [ {id: 1, name: 'bar'}, {id: 2, name:
我想用 Backbone.Marionette 创建一个 View 来呈现模型,然后维护 2 个或更多 CollectionView。基本上是一个具有多个 CollectionView 的 Compo
我想从 Marionette.ItemView 访问 app.vent。 也许可以选择将参数 (app.vent) 从 Marionette.CompositeView 传递到 Marionette.
我们必须显示以下 View : 类别(显示为表格),每个类别表格应该有产品(tr)。 我们如何使用 Marionette itemView 和 CompositeView 构建它? 我们需要产品成为一
我处于以下情况。 当 collection.length = 0 我想将一个参数传递给 listTemplate 以便在 listTemplate 中显示一条消息(没有模型存在!)。我怎样才能实现我的
我有一个具有父子关系的模型,我想在表格显示中显示每个父级,然后是子级,我将在其中稍微缩进子级。我已经快到了,但我似乎只能将子项附加到父行,而不是将它们添加到父行之后。 View.TreeView =
实际上,我想更改现有 Marionette CompositeView 中的整个集合,而不为该 View 创建新对象。 我无法找到用于此目的的方法我已阅读文档 here 最佳答案 您应该能够通过使用集
我不知道为什么这段代码不起作用。 阅读documentation , 应该调用 templateHelpers。 我的目标是将 this.collection.length 传递给模板。 有什么提示吗
我想显示集合中的前 100 个条目,或 101 到 200 之间的条目。 如果我创建一个 Marionette CompositeView 并指定 someRegion.show new MyComp
我现在坚持了。我收到以下错误: TypeError: listenTo is undefined return listenTo.call(this, evtSource, events, _.
我正在尝试设置一个简单的 Marionette 的 CompositeView。这就是我最终想要的: %select#target-id %option{:value => "#{@id}"} =
通过使用 jasmine,我正在尝试测试一个返回 Marionette.CompositeView 的 javascript 模块。 这是 javascript 模块 (2) 和 javascript
我想测试一个模块的行为(使用 Marionette )是否有效 (1)。 奇怪的是,js 模块 (1) 有效,但单元测试 (2) 使用 Jasmine失败。 有什么想法吗? (1) /*global
我是一名优秀的程序员,十分优秀!