- xml - AJAX/Jquery XML 解析
- 具有多重继承的 XML 模式
- .net - 枚举序列化 Json 与 XML
- XML 简单类型、简单内容、复杂类型、复杂内容
我希望列出为我的应用程序中的每个页面呈现的部分内容。例如,当显示 app/tasks/index.html.erb 页面时,我想向用户显示如下内容:
Partials rendered for this page:
tasks/_list.html.erb
tasks/_button.html.erb
tasks/_navigation.html.erb
在 Ruby on Rails 中有什么方法可以做到这一点吗?
最佳答案
是的,在 Rails 中完全可以做到这一点!
正如 bdares 在他的评论中指出的那样,用于模板渲染的行出现在日志中。但他们最初是如何到达那里的呢?好吧,这与 little something in Active Support called LogSubscriber
有关.这方面的文档非常详尽:
ActiveSupport::LogSubscriber is an object set to consume ActiveSupport::Notifications with the sole purpose of logging them. The log subscriber dispatches notifications to a registered object based on its given namespace.
将“Rendered ...”行放入日志的是 ActionView::LogSubscriber
这是定义 like this within Rails 3.2 .花点时间阅读代码。它漂亮整洁。
这是在订阅 Rails 中的几个事件,即 render_template
。 , <强> render_partial
和 render_collection
方法。它通过调用 ActiveSupport::LogSubscriber.attach_to
来做到这一点方法,它将日志订阅者附加到某些事件。那个方法也很有趣,定义如下:
def attach_to(namespace, log_subscriber=new, notifier=ActiveSupport::Notifications)
log_subscribers << log_subscriber
@@flushable_loggers = nil
log_subscriber.public_methods(false).each do |event|
next if 'call' == event.to_s
notifier.subscribe("#{event}.#{namespace}", log_subscriber)
end
end
我已将此代码放在一行中,因为它与我们的兴趣极为相关。这是在调用subscribe
在 notifier
上目的。 notifier
默认情况下,对象是 ActiveSupport::Notifications
,记住这一点很重要。 documentation for that class in Rails is in the API too .
当 subscribe
被调用,它通过 event
的名称.这是什么?好吧,它是类中的每一个公共(public)方法。当 LogSubscriber
定义了子类,它定义了几个公共(public)方法:render_template
, <强> render_partial
和 render_collection
.这些是将为该日志订阅者订阅的事件。
现在,这与我们的兴趣相关,因为我们将使用相同的东西来订阅 View 内的这些事件。第一步是让ActiveSupport::Notfications
我们想要订阅所有部分渲染事件。我们可以通过创建一个新的 before_filter
来做到这一点在 ApplicationController
内:
before_filter :log_partial_events
def log_partial_events
@partial_events = []
ActiveSupport::Notifications.subscribe("render_partial.action_view") do |event_name, start_at, end_at, id, payload|
@partial_events << payload[:identifier]
end
我们订阅的事件是 render_partial
action_view
内的事件命名空间,这正是 ActionView::LogSubscriber
的事件之一正在订阅。呈现部分时会发生什么情况,即调用此 block 并传入一些数据。
event_name
:事件的名称。 start_at
:事件开始的时间。 end_at
:事件结束的时间。 id
:此事件的唯一标识符。 payload
: 关于这个事件的一些负载信息。
当钩子(Hook)被调用时,它会添加 identifier
来自 payload
的 key 到方法顶部定义的数组。
然后在 View 中,要访问这些列表,您可以这样做:
<%= debug @partial_events %>
关于ruby-on-rails - ruby rails : How do you list the partial paths that are rendered for a page?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/15468894/
我需要在每个渲染帧完成后拍摄屏幕截图,但我发现某些屏幕截图是重复的,所以我想知道是否可以在渲染完成之前保存屏幕截图。因此... renderer.render() 会阻塞直到完成渲染吗? 如果没有,有
web.py 骨架代码中的“render._keywords['globals']['render'] = render”是什么意思? http://webpy.org/skeleton/0.3 最佳
所以在我的 Nuxt universal-mode 应用程序中,我有时会出现错误: vue.runtime.esm.js:620 [Vue warn]: The client-side rendere
我想创建一个 portal-like effect使用 Bevy . Unity 似乎有一个 render texture实现这一目标。 有没有办法在 Bevy 中做同样的事情?如果没有, futur
我有一个看起来像这样的组件(非常简化的版本): const component = (props: PropTypes) => { const [allResultsVisible, setA
编辑:我调整了代码,但问题仍然存在。见下文 我有这个 p:selectOneRadio : 而这个 p:radioButton : 和 AData包含其
为了渲染部分我可以使用 render 'partial_name' 或 render partial: 'partial_name' 我开始知道 render 是 render partial 的简写
我注意到文章中的一些地方使用了 React.render() 和一些地方 ReactDOM.render()。这两者有什么具体区别吗? 最佳答案 这是 0.14 中引入的最新更改。他们将 React
我的代码是这样的: function render() { renderer.render( scene, camera ); renderer.clear(); } 我想知道为什么它
我目前正在实现 useSWR 以便从我的 express 和 mongo-db 后端获取数据。我能够从数据库中成功获取数据没问题。以下是我用来实现此目的的代码: ```//SWR method for
我只有在按照 React native - "this.setState is not a function" trying to animate background color? 的建议合并了 u
所以我有一个大的纹理,被分成 64x64 block 。 我使用将其加载到 LibGDX texture = new Texture("texturemap.png"); regions = Text
我对放置 @Scripts.Render 和 @Styles.Render 的位置感到很困惑。理想情况下,我会将它们全部放在 head 部分中,但出乎意料的是,例如 @Scripts.Render("
我正在尝试使用 jamon 来收集使用 Tapestry 的网站的统计信息(呈现网页的时间)。 我怎样才能拥有 服务器收到请求时执行的方法,即渲染开始时? 响应全部发送完毕,即渲染结束时执行的方法 ?
在我的 React 应用程序中,我想要渲染一个 prop 值,但直到渲染完成后更新 props 后它才存在。 this.props.users 是一个对象,因此我使用 Object.keys() 转换
我正在使用 React 的钩子(Hook),我希望有一个从数据库中检索到的值作为初始值。但是,我收到以下错误: Invariant Violation: Invariant Violation: Re
我正在尝试按照以下代码将多个场景包含到单个 webgl 渲染器中: renderer.render(scene1, camera); renderer.render(scene2, camera);
我在我的 xhtml 页面中使用此代码,当我运行应用程序时,元描述仍在呈现。我想根据某些条件使用元描述标签。主布局: ..........
我正在使用react-native-render-html来渲染html。renderers方法允许我提供自定义函数来呈现特定标签。不过,我想使用源代码中的原始内部 HTML 将子组件替换为我的自定义
我有一个网格,可以渲染可变高度的卡片。 为了获取卡片的高度,我将卡片渲染在 ReactHeight 中。 ( https://github.com/nkbt/react-height ),这让我可以在
我是一名优秀的程序员,十分优秀!