- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在编写测试,其中 onAttach 生命周期方法中有一些逻辑,但在测试时永远不会调用 onAttach。
这就是我最初尝试测试它的方式
beforeEach(() => {
view = new OffersTab();
view.render();
});
但我的理解是,当显示区域时,它的 onAttach 会被触发,所以我尝试这样做,
beforeEach(() => {
let parentView = new AllOffers();
parentView.render();
parentView.getRegion('offersTab').show(new OffersTab());
view = parentView.getRegion('offersTab');
});
但是 onAttach 仍然没有触发,让我无法编写测试
最佳答案
attach
event 之间存在差异在 View 和 show
event在一个地区。 (onAttach
方法是一种便捷方法,不需要通过 listenTo
订阅。)
当您的 View 显示在某个区域中时,会触发 attach
事件,并且这会将 View 附加到 DOM - 附加到其祖先位于页面中的元素文档
(document.documentElement
)。这意味着 View 的元素 (el
) 或父 View 或祖先 View 的元素已附加到 DOM。仅在父 View 区域中显示 View 是不够的。首先,当该父 View 附加到 DOM 时,该事件将递归地触发到所有 subview 。
在显示 subview 之前,您可以通过测试 parentView
来检查它:
// All will return false
document.documentElement.contains(parentView.el);
Marionette.isNodeAttached(parentView.el);
parentView.isAttached();
如果您的 View 需要附加到 DOM 才能正常工作,您必须选择 DOM 中的一个元素并在其中显示父 View 。例如,在 document.body
中:
let body, parentView, view;
before(() => { // mocha's "before all"
body = new Marionette.Region({ el: 'body' });
});
beforeEach(() => {
parentView = new AllOffers();
body.show(parentView); // attach the parent view to DOM
view = new OffersTab();
parentView.getRegion('offersTab').show(view);
});
afterEach(() => {
body.empty(); // detach and destroy the view
});
或者,您可以将 AllOffers
附加到 DOM 本身及其代码。或者将 DOM 中的元素传递给其构造函数,例如:new AllOffers({ el: body })
。当你不需要它时,不要记得销毁它。
当 View 在某个区域中显示时,show
事件将在该区域上触发,而不是在 View 上触发。 (我写的是 Marionette 3 或更新版本。Marionette 2 触发了 View 上的 show
事件。)
如果您的事件处理程序需要在父 View 区域中显示 View 后立即执行,而不是在 View 出现在 DOM 中后执行,请考虑将代码移至 render
event (或 onRender
方法)。您可以监听该区域的 show
事件并在您的 subview 上重新触发它,但您最好遵循 Marionette 的最佳实践和 use other events .
关于javascript - Marionette onAttach 生命周期在测试期间未触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58187178/
我真的不明白它们是如何有用的。原文article引入了初始化程序,这是代码示例: App = new Backbone.Marionette.Application(); App.addInitial
我正在准备使用 Backbone Marionette 迁移我的应用程序,但路由中出现错误: window.App = new Backbone.Marionette.Application
我正在尝试将 marionette.js 用于我的 Backbone 应用程序,但我对如何组织布局/区域并呈现它们感到有些困惑。 我正在寻找具有嵌套布局和区域的示例应用程序,以便我能更好地理解它。有什
我有一个带有区域的布局。当 Layout 初始化时,我希望它自动初始化一个预设 View 以进入它的区域,并在 Layout 本身显示/关闭时显示/关闭它。 当前示例来自 https://github
//当我点击 kickassessor 按钮时,它会更新数据库,但 View 不会更新。这是我的代码。 返回 Marionette.ItemView.extend( { initialize
我有需要显示/编辑的数据,这些数据似乎与 Marionette 提供的内置 View 不自然。让我举个例子来说明。 假设我想列出/编辑书籍。每本书都有一个 ISBN、一个书名和 0 个或多个标签。基本
我一直在查看各种 Marionette 问题,但没有找到我想要的,希望有人能给我一些合理的建议和一些建议。我是新手,只是想在我在 github 上选择的样板启动包上构建 https://github.
随着我的应用程序的增长,我觉得需要更结构化的路由器/ Controller 设置。 Marionette 文档提到以下内容: It is recommended that you divide you
在我的应用程序中,我添加了 Marionette.sync 插件并覆盖这些方法: Backbone.Marionette.TemplateCache.prototype.loadTemplate =
我想知道是否有可能以某种方式扩展 Marionette Layout 机制基于创建一种类似导航的堆栈。 Marionette 行为。 在区域 show() 的 View 之前,它会在当前显示的 Vie
看起来 Backbone.Marionette View 为事件等操作 DOM,所以我猜这不像更改基类引用那样微不足道,例如Backbone.View 到 BaseView。 有没有人解决过这个问题?
我正在使用 Marionette Layout .show渲染 CollectionView并想知道是否有办法检测 全部 ItemView children 已经完成了渲染? 我的代码的简化版本是:
因此,我不确定我是否完全理解应该如何触发此回调。如果您采用准系统模型、集合和 View : PatchModel = Backbone.Model.extend({}); PatchCollectio
我正在查看 Backbone Marionette,它似乎对我当前的项目很有前途。但是,无论 startWithParent 设置如何,添加模块时它们似乎都会自动启动。这是我遇到问题的一段代码(其中一
我是 Marionette 的新手,无法理解事件... 我有一个触发事件的 ItemView,我想在应用程序级别接收此事件,但是当我的应用程序监听此事件时,没有任何 react ... 如果事件聚合器
我有一个 CollectionView class MyCollectionView extends Backbone.Marionette.CollectionView itemView: My
我有一个复合 View ,在将模型添加到 View 集合时抛出以下错误:Uncaught ItemViewContainerMissingError: Missing itemViewContaine
我已经建立了一个项目,在其中扩展了包含两个不同区域的 Backbone.Marionette.Layout。该布局可以用作整个应用程序的组件。特别是,区域设置如下。 regions : { m
基本上,我试图将 CompositeView 呈现为一个简单的四列列表,其中包含一个表头,其中集合中的每个模型都呈现为一个并附加到 .我正在关注 an example of Derick's非常接近,
我正在尝试包含应用程序实例以使用其事件聚合器,如图所示 here 当我将实例包含在 View 中时,出现错误。 在 Requirejs 配置文件中启动 App.Bootloader.js: requi
我是一名优秀的程序员,十分优秀!