首页
/ AlchemyCMS v7.4.0发布:告别CoffeeScript,拥抱现代前端工具链

AlchemyCMS v7.4.0发布:告别CoffeeScript,拥抱现代前端工具链

2025-07-10 09:32:53作者:伍希望

AlchemyCMS是一个基于Ruby on Rails开发的内容管理系统,以其强大的内容编辑功能和灵活的架构而闻名。最新发布的v7.4.0版本标志着该项目在前端技术栈上的重大革新,彻底告别了CoffeeScript时代,全面转向现代JavaScript工具链。

前端技术栈全面升级

本次版本最核心的变化是彻底移除了对CoffeeScript的依赖。CoffeeScript作为一种JavaScript的语法糖,曾经在前端开发中流行一时,但随着ES6+标准的普及和现代前端工具链的成熟,它已逐渐退出历史舞台。AlchemyCMS团队果断地完成了这一技术迁移,使得整个项目的JS和CSS构建不再依赖Sprockets(虽然目前仍保留为依赖项,计划在8.0版本中完全移除)。

这一转变带来了多项技术改进:

  • 所有JavaScript代码现在都使用ES模块规范编写
  • 前端资源构建完全采用现代工具链
  • 为未来支持propshaft(Rails 7.1+的资产管道替代方案)铺平了道路

显著功能增强

可调整大小的元素窗口

编辑器界面中的元素窗口现在支持调整大小,这大大改善了内容编辑体验,特别是在处理复杂布局时。

视图组件生成器

新增的ingredient生成器现在能够自动创建视图组件,这符合现代前端开发的最佳实践,使得自定义内容元素的开发更加规范和高效。

图片alt文本编辑优化

图片alt文本表单字段的高度得到了调整,使编辑长描述文本更加方便。

管理员界面样式扩展

现在可以通过配置添加额外的样式表到管理员界面,为项目定制提供了更大的灵活性。

安全性与用户体验改进

外部链接安全增强

所有外部链接现在都自动添加了rel="noopener noreferrer"属性,这是防范tabnabbing攻击的重要安全措施。

图片裁剪工具升级

用cropperjs替代了老旧的Jcrop库,提供了更现代、功能更强大的图片裁剪体验。

SVG图标预加载

SVG图标精灵现在会被预加载,减少了界面渲染时的延迟,提升了用户体验。

技术架构演进

依赖管理现代化

  • jQuery和Select2现在通过importmap加载
  • Handlebars模板从npm直接引入
  • TinyMCE插件被捆绑到主包中

测试环境优化

CI环境从MySQL切换到SQLite,简化了测试配置,同时测试矩阵增加了对Ruby 3.4.1和Rails 8.0的支持。

开发者体验提升

运行时模块控制器验证

模块控制器现在在运行时进行验证,提供了更灵活的扩展机制。

Turbo Streams应用

多个界面交互改用Turbo Streams实现,包括页面配置对话框和元素创建流程,使界面更新更加流畅。

导航辅助方法优化

导航辅助方法改用#send实现,提高了代码的灵活性和可维护性。

向后兼容性考虑

虽然移除了CoffeeScript支持,但团队保持了Sprockets的暂时依赖,确保现有项目能够平稳过渡。这一设计决策体现了对现有用户的尊重和对生态系统稳定性的重视。

总结

AlchemyCMS v7.4.0是一次重要的技术升级,它不仅跟上了现代Web开发的步伐,还为未来的发展奠定了更坚实的基础。通过拥抱ES模块、现代化前端工具链和最新Rails特性,这个版本在保持强大内容管理功能的同时,显著提升了开发体验和系统性能。对于现有用户来说,升级到这个版本将获得更流畅的管理界面和更现代的代码库;对于新用户而言,这降低了入门门槛,使AlchemyCMS成为一个更具吸引力的内容管理解决方案。

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

热门内容推荐

最新内容推荐

项目优选

收起
docsdocs
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
143
1.91 K
kernelkernel
deepin linux kernel
C
22
6
nop-entropynop-entropy
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
8
0
ohos_react_nativeohos_react_native
React Native鸿蒙化仓库
C++
192
273
RuoYi-Vue3RuoYi-Vue3
🎉 (RuoYi)官方仓库 基于SpringBoot,Spring Security,JWT,Vue3 & Vite、Element Plus 的前后端分离权限管理系统
Vue
927
551
openHiTLSopenHiTLS
旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
421
392
openGauss-serveropenGauss-server
openGauss kernel ~ openGauss is an open source relational database management system
C++
145
189
金融AI编程实战金融AI编程实战
为非计算机科班出身 (例如财经类高校金融学院) 同学量身定制,新手友好,让学生以亲身实践开源开发的方式,学会使用计算机自动化自己的科研/创新工作。案例以量化投资为主线,涉及 Bash、Python、SQL、BI、AI 等全技术栈,培养面向未来的数智化人才 (如数据工程师、数据分析师、数据科学家、数据决策者、量化投资人)。
Jupyter Notebook
75
64
Cangjie-ExamplesCangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
344
1.3 K
easy-eseasy-es
Elasticsearch 国内Top1 elasticsearch搜索引擎框架es ORM框架,索引全自动智能托管,如丝般顺滑,与Mybatis-plus一致的API,屏蔽语言差异,开发者只需要会MySQL语法即可完成对Es的相关操作,零额外学习成本.底层采用RestHighLevelClient,兼具低码,易用,易拓展等特性,支持es独有的高亮,权重,分词,Geo,嵌套,父子类型等功能...
Java
36
8