Transitions 项目技术文档
1. 安装指南
1.1 在 Rails 项目中安装
在 Rails 项目中,可以通过 Gemfile 安装 transitions
库。首先,在 Gemfile 中添加以下内容:
gem "transitions", :require => ["transitions", "active_model/transitions"]
然后,在你的 ORM 模型中引入 ActiveModel::Transitions
:
include ActiveModel::Transitions
1.2 独立安装
如果你不在 Rails 项目中,可以通过以下命令安装 transitions
:
gem install transitions
安装完成后,在你的类中引入 Transitions
:
include Transitions
2. 项目的使用说明
transitions
是一个 Ruby 状态机实现库,允许你在模型中定义状态和状态转换。以下是一个简单的使用示例:
class Product
include ActiveModel::Transitions
state_machine do
state :available # 初始状态
state :out_of_stock, :exit => :exit_out_of_stock
state :discontinued, :enter => lambda { |product| product.cancel_orders }
event :discontinued do
transitions :to => :discontinued, :from => [:available, :out_of_stock], :on_transition => :do_discontinue
end
event :out_of_stock, :success => :reorder do
transitions :to => :out_of_stock, :from => [:available, :discontinued]
end
event :available do
transitions :to => :available, :from => [:out_of_stock], :guard => lambda { |product| product.in_stock > 0 }
end
end
end
在这个示例中,我们定义了一个 Product
类,并为其定义了三个状态:available
、out_of_stock
和 discontinued
。每个状态都可以定义进入和退出时的回调方法。
3. 项目 API 使用文档
3.1 获取和设置当前状态
使用 current_state
方法可以获取当前状态。如果你没有显式设置状态,将返回初始状态:
>> Product.new.current_state
=> :available
你也可以通过 update_current_state(new_state, persist = true / false)
方法显式设置新状态,但不建议直接使用此方法,除非你非常清楚自己在做什么。
3.2 事件
每个事件定义会生成三个方法:事件名称、事件名称加 !
和 can_事件名称?
。例如,定义一个 discontinue
事件会生成 discontinue
、discontinue!
和 can_discontinue?
方法。
discontinue
和discontinue!
方法会在成功转换时修改state
属性,但只有discontinue!
会调用save!
方法。can_discontinue?
方法不会修改状态,而是返回一个布尔值,表示给定的转换是否可能。
3.3 回调
transitions
提供了多种回调,允许你在状态转换的不同阶段执行代码:
- State callbacks (
enter
和exit
):在进入或退出状态时触发。 - Transition callback (
on_transition
):在转换过程中执行的回调。 - Event callback (
success
):在成功转换后执行的回调。
4. 项目安装方式
4.1 在 Rails 项目中安装
在 Rails 项目中,通过 Gemfile 安装 transitions
:
gem "transitions", :require => ["transitions", "active_model/transitions"]
然后在模型中引入 ActiveModel::Transitions
:
include ActiveModel::Transitions
4.2 独立安装
通过以下命令安装 transitions
:
gem install transitions
安装完成后,在类中引入 Transitions
:
include Transitions
通过以上步骤,你可以在项目中成功安装并使用 transitions
库。
- PDFMathTranslatePDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython03
- topiam-eiam开源IDaas/IAM平台,用于管理企业内员工账号、权限、身份认证、应用访问,帮助整合部署在本地或云端的内部办公系统、业务系统及三方 SaaS 系统的所有身份,实现一个账号打通所有应用的服务。Java00
- 每日精选项目🔥🔥 12.24日推荐:高性能 C 语言 UI 布局库🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~017
- Cangjie-Examples本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie039
- 毕方Talon工具本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python039
- advanced-javaAdvanced-Java是一个Java进阶教程,适合用于学习Java高级特性和编程技巧。特点:内容深入、实例丰富、适合进阶学习。JavaScript0102
- taro开放式跨端跨框架解决方案,支持使用 React/Vue/Nerv 等框架来开发微信/京东/百度/支付宝/字节跳动/ QQ 小程序/H5/React Native 等应用。 https://taro.zone/TypeScript010
- Yi-CoderYi Coder 编程模型,小而强大的编程助手HTML012
- CommunityCangjie-TPC(Third Party Components)仓颉编程语言三方库社区资源汇总05
- Bbrew🍺 The missing package manager for macOS (or Linux)Ruby01