- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有需要显示/编辑的数据,这些数据似乎与 Marionette 提供的内置 View 不自然。让我举个例子来说明。
假设我想列出/编辑书籍。每本书都有一个 ISBN、一个书名和 0 个或多个标签。基本上,信息的显示将以表格形式显示(标签下的每个单词都是一个单独的标签,可以单独编辑/删除):
+---------+----------------+-----------------------------+
|ISBN |Title |Tags |
+=========+================+=============================+
|12345678 |My Last Summer |vacation diary kids |
+---------+----------------+-----------------------------+
|12354389 |The Day After |fiction future |
+---------+----------------+-----------------------------+
如果每本书只有一个标签,那么 CompositeView/ItemView 就可以很好地工作。我在想的是在每行的最后一个单元格中动态创建区域,然后使用 CompositeView/ItemView 来处理标签列表。也许这是矫枉过正,在模板中使用某种迭代器是可行的方法。
我考虑过捕获标签并使用特定书籍的标签列表填充单个字符串。我可以通过处理从后端接收的数据来实现这一点,从而将标签列表变成单个数据元素,这样我就可以使用 CompositeView/ItemView 将其作为一个简单的表格来处理。这确实引入了一个额外的“映射”,并且实现“编辑” View 的事情会变得更加复杂。
所以我只是希望听到人们是否遇到过这种要求,以及适合 Marionette 的方法是什么。谢谢。
最佳答案
正如您已经发现的那样,您可以通过多种不同的方式来完成这项工作。每个选项都将更适合一组特定的情况,但也有可能您的情况没有“最佳”方法来完成您想要的。如果是这种情况,只需选择一个并继续前进。 :)
这就是您已经提出的建议。它适用于标签数量相对较少并且您不需要在有人点击特定标签时采取任何自定义操作的情况。例如,如果您只是将每个标签设置为 <a href="#{tag-name}">
链接,您可以使用向下映射到简单数组的标签轻松地做到这一点。
与映射选项基本相同,除了不是将标签简化为简单的字符串数组,而是将模板中的标签集合作为模型迭代,并调用 model.get(...) 以便获取您需要的数据。
如果您使用的是像 Handlebars 这样的模板引擎,这将变得非常容易,并且通过使用子模板可能会产生更干净的结果。
不过,我可能不会为下划线模板推荐这种方法,因为在进行迭代时,它们往往会很快变得困惑和丑陋。
这是更复杂的选项,但也是最有能力的。
配置itemView
用于收集书籍作为布局。布局中将有一个区域,该区域将填充另一个 Collection View 以呈现每个单独的标签。
这样做的好处是,您可以拥有更多与正在呈现的个人标签相关联的代码和功能。每个标签都有一个 View 实例,这意味着可以更轻松地封装和组织该代码。
缺点是每个标签都有一个 View 实例,并且需要编写更多代码才能设置和运行。
复合 View 可让您围绕集合呈现包装器模板,这可能被证明是优于 CollectionView 的优势。
您仍然需要一个 CollectionView。此 CollectionView 将呈现一个 CompositeView,因为它是 itemView
。 . CompositeView 将指定 itemViewContainer
呈现标签集合。每个标签都有自己的 View 实例。
您可以通过这种方式摆脱布局和区域。视觉结果与使用带有布局的 CollectionView 相同,但执行此操作的代码量可能会显着减少。
就我个人而言,我要么通过 map/reduce 将标签简化为一个简单的数组,要么使用 CompositeViews 的 CollectionView。
关于marionette - 使用 Backbone.Marionette 在集合中显示集合,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13184319/
我的Angular-Component位于一个flexbox(id =“log”)中。可以显示或隐藏flexbox。 我的组件内部有一个可滚动区域,用于显示日志消息。 (id =“message-li
我真的很困惑 有一个 phpinfo() 输出: MySQL 支持 启用 客户端 API 版本 5.5.40 MYSQL_MODULE_TYPE 外部 phpMyAdmin 显示: 服务器类型:Mar
我正在研究这个 fiddle : http://jsfiddle.net/cED6c/7/我想让按钮文本在单击时发生变化,我尝试使用以下代码: 但是,它不起作用。我应该如何实现这个?任何帮助都会很棒
我应该在“dogs_cats”中保存表“dogs”和“cats”各自的ID,当看到数据时显示狗和猫的名字。 我有这三个表: CREATE TABLE IF NOT EXISTS cats ( id
我有一个字符串返回到我的 View 之一,如下所示: $text = 'Lorem ipsum dolor ' 我正在尝试用 Blade 显示它: {{$text}} 但是,输出是原始字符串而不是渲染
我无法让我的链接(由图像表示,位于页面左侧)真正有效地显示一个 div(包含一个句子,位于中间)/单击链接时隐藏。 这是我的代码: Practice
关闭。这个问题需要多问focused 。目前不接受答案。 想要改进此问题吗?更新问题,使其仅关注一个问题 editing this post . 已关闭 4 年前。 Improve this ques
最初我使用 Listview 来显示 oracle 结果,但是最近我不得不切换到 datagridview 来处理比 Listview 允许的更多的结果。然而,自从切换到数据网格后,我得到的结果越来越
我一直在尝试插入一个 Unicode 字符 ∇ 或 ▽,所以它显示在 Apache FOP 生成的 PDF 中。 这是我到目前为止所做的: 根据这个基本帮助 Apache XSL-FO Input,您
我正在使用 node v0.12.7 编写一个 nodeJS 应用程序。 我正在使用 pm2 v0.14.7 运行我的 nodejs 应用程序。 我的应用程序似乎有内存泄漏,因为它从我启动时的大约 1
好的,所以我有一些 jQuery 代码,如果从下拉菜单中选择了带有前缀 Blue 的项目,它会显示一个输入框。 代码: $(function() { $('#text1').hide();
当我试图检查 Chrome 中的 html 元素时,它显示的是 LESS 文件,而 Firefox 显示的是 CSS 文件。 (我正在使用 Bootstrap 框架) 如何在 Chrome 中查看 c
我是 Microsoft Bot Framework 的新手,我正在通过 youtube 视频 https://youtu.be/ynG6Muox81o 学习它并在 Ubuntu 上使用 python
我正在尝试转换从 mssql 生成的文件到 utf-8。当我打开他的输出 mssql在 Windows Server 2003 中使用 notepad++ 将文件识别为 UCS-2LE我使用 file
很难说出这里问的是什么。这个问题是含糊的、模糊的、不完整的、过于宽泛的或修辞性的,无法以目前的形式得到合理的回答。如需帮助澄清此问题以便重新打开它,visit the help center 。 已关
我正在尝试执行单击以打开/关闭一个 div 的功能。 这是基本的,但是,点击只显示 div,当我点击“关闭”时,没有任何反应。 $(".inscricao-email").click(function
假设我有 2 张卡片,屏幕上一次显示一张。我有一个按钮可以用其他卡片替换当前卡片。现在假设卡 1 上有一些数据,卡 2 上有一些数据,我不想破坏它们每个上的数据,或者我不想再次重建它们中的任何一个。
我正在使用 Eloquent Javascript 学习 Javascript。 我在 Firefox 控制台上编写了以下代码,但它返回:“ReferenceError:show() 未定义”为什么?
我正在使用 Symfony2 开发一个 web 项目,我使用 Sonata Admin 作为管理面板,一切正常,但我想要做的是,在 Sonata Admin 的仪表板菜单上,我需要显示隐藏一些菜单取决
我试图显示一个div,具体取决于从下拉列表中选择的内容。例如,如果用户从列表中选择“现金”显示现金div或用户从列表中选择“检查”显示现金div 我整理了样本,但样本不完整,需要接线 http://j
我是一名优秀的程序员,十分优秀!