- #
- A
- B
- P
- S
实例公共方法
_insert_callbacks(callbacks, block = nil) 链接
接收回调名称和一个可选的回调过程,对其进行规范化,然后使用每个回调调用该块。这使我们能够跨多个使用它的方法抽象规范化。
参数
-
callbacks
- 回调数组,最后一个参数是可选的选项哈希。 -
block
- 应该添加到回调中的一个过程。
块参数
-
name
- 要添加的回调。 -
options
- 用于添加回调的选项哈希。
来源: 显示 | 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 120 def _insert_callbacks(callbacks, block = nil) options = callbacks.extract_options! callbacks.push(block) if block options[:filters] = callbacks _normalize_callback_options(options) options.delete(:filters) callbacks.each do |callback| yield callback, options end end
_normalize_callback_options(options) 链接
如果使用:only
或:except
,则将选项转换为ActiveSupport::Callbacks
的:if
和:unless
选项。
基本思想是:only => :index
被转换为:if => proc {|c| c.action_name == "index" }
。
请注意,如果一起使用,:only
优先于:if
。
only: :index, if: -> { true } # the :if option will be ignored.
请注意,如果一起使用,:if
优先于:except
。
except: :index, if: -> { true } # the :except option will be ignored.
选项
-
only
- 回调应该只对该操作运行。 -
except
- 回调应该对除了该操作之外的所有操作运行。
来源: 显示 | 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 93 def _normalize_callback_options(options) _normalize_callback_option(options, :only, :if) _normalize_callback_option(options, :except, :unless) end
after_action(names, block) 链接
在操作后追加回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 173
append_after_action(names, block) 链接
在操作后追加回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 194
append_around_action(names, block) 链接
在操作周围追加回调。有关参数详细信息,请参见_insert_callbacks
。为 before、after 和 around 中的每一个设置 before_action
、prepend_before_action
、skip_before_action
等。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 223
append_before_action(names, block) 链接
在操作之前追加回调。有关参数详细信息,请参见_insert_callbacks
。
如果回调渲染或重定向,则操作将不会运行。如果还有其他回调计划在该回调之后运行,它们也会被取消。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 162
around_action(names, block) 链接
在操作周围追加回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 201
before_action(names, block) 链接
在操作之前追加回调。有关参数详细信息,请参见_insert_callbacks
。
如果回调渲染或重定向,则操作将不会运行。如果还有其他回调计划在该回调之后运行,它们也会被取消。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 132
prepend_after_action(names, block) 链接
在操作后预置回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 180
prepend_around_action(names, block) 链接
在操作周围预置回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 208
prepend_before_action(names, block) 链接
在操作之前预置回调。有关参数详细信息,请参见_insert_callbacks
。
如果回调渲染或重定向,则操作将不会运行。如果还有其他回调计划在该回调之后运行,它们也会被取消。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 143
skip_after_action(names) 链接
跳过操作后的回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 187
skip_around_action(names) 链接
跳过操作周围的回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 216
skip_before_action(names) 链接
跳过操作之前的回调。有关参数详细信息,请参见_insert_callbacks
。
来源: 在 GitHub 上
# File actionpack/lib/abstract_controller/callbacks.rb, line 155