首页
/ Bullet Train项目v1.21.0版本发布:移除rails-ujs的重大变更解析

Bullet Train项目v1.21.0版本发布:移除rails-ujs的重大变更解析

2025-06-27 04:12:58作者:温玫谨Lighthearted

Bullet Train是一个基于Ruby on Rails的全栈开发框架,它为开发者提供了构建现代化Web应用所需的各种工具和组件。该框架特别注重开发效率和最佳实践,整合了Turbo、Stimulus等现代前端技术栈。

版本核心变更:移除rails-ujs

v1.21.0版本最重要的变更是移除了对rails-ujs的依赖,转而全面采用Turbo来处理前端交互。这一变更可能会影响现有应用中使用了特定特性的部分,特别是涉及以下两种场景:

  1. 使用了双因素认证的应用:如果不进行相应调整,登录流程将会中断
  2. 使用了特定数据属性的链接和按钮:包括method和confirm等特性

迁移指南

link_to标签的更新

在旧版本中,开发者通常会这样使用link_to标签:

<%= link_to "删除项目", project_path(@project), method: :delete, data: { confirm: "确定删除吗?" } %>

在新版本中,需要调整为Turbo兼容的格式:

<%= link_to "删除项目", project_path(@project), data: { turbo_method: :delete, turbo_confirm: "确定删除吗?" } %>

主要变更点:

  • method参数改为turbo_method并移至data哈希中
  • confirm参数改为turbo_confirm

button_to标签的更新

对于button_to标签,主要需要调整confirm参数的命名:

旧版本写法:

<%= button_to "注销账户", user_path(@user), method: :delete, data: { confirm: "确定要注销吗?" } %>

新版本写法:

<%= button_to "注销账户", user_path(@user), method: :delete, data: { turbo_confirm: "确定要注销吗?" } %>

注意:button_to的method参数保持不变,只需修改confirm为turbo_confirm。

兼容性处理

如果暂时无法完成迁移,开发者可以选择回退到使用rails-ujs:

  1. 添加rails-ujs包:
yarn add @rails/ujs
  1. 在application.js中添加:
import Rails from "@rails/ujs"
Rails.start()

其他改进

除了主要的rails-ujs变更外,本次版本还包含:

  1. 解决了Stimulus清单文件在生成新控制器时被覆盖的问题
  2. 常规的依赖项更新,包括Ruby和JavaScript依赖

升级建议

对于正在使用Bullet Train框架的开发者,建议:

  1. 首先检查应用中是否使用了受影响的功能
  2. 使用提供的grep命令查找需要修改的地方
  3. 考虑直接升级到v1.21.1版本,该版本修复了双因素认证的问题
  4. 全面测试应用中的交互功能,特别是涉及数据修改的操作

这一变更虽然需要一定的迁移工作,但将使应用更加符合现代Rails开发的最佳实践,为未来的功能扩展打下更好的基础。

登录后查看全文
热门项目推荐

项目优选

收起
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
176
260
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
858
507
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
129
182
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
255
299
ShopXO开源商城ShopXO开源商城
🔥🔥🔥ShopXO企业级免费开源商城系统,可视化DIY拖拽装修、包含PC、H5、多端小程序(微信+支付宝+百度+头条&抖音+QQ+快手)、APP、多仓库、多商户、多门店、IM客服、进销存,遵循MIT开源协议发布、基于ThinkPHP8框架研发
JavaScript
93
15
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
331
1.08 K
HarmonyOS-ExamplesHarmonyOS-Examples
本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
397
370
note-gennote-gen
一款跨平台的 Markdown AI 笔记软件,致力于使用 AI 建立记录和写作的桥梁。
TSX
83
4
CangjieCommunityCangjieCommunity
为仓颉编程语言开发者打造活跃、开放、高质量的社区环境
Markdown
1.07 K
0
kernelkernel
deepin linux kernel
C
21
5