为Web开发提供的10个Ruby on Rails Gems

简介:

在这里,值得推荐的 Ruby on Rails 的 web 开发的插件包括 Capistrano 和 Foreigner。

我用 Ruby on Rails 开发已经有很多年了,用这个优秀的框架我完成了很多任务,其中有些可以算是非常复杂的项目。基于我的经验,我来推荐一些我觉得非常有用的 gem。本文就会分享这个推荐列表,还会告诉你如何找到 RoR 有用的 gem。

不幸的是,gem 的格式描述不支持分类和标签。所以我们不得不期望 gem 的作者在描述里列出我们需要的关键字,这样在搜索的时候才能更好的得到结果。你可以在 rubygems.org 或者 github.com 上找到很多 gem。可以通过描述去进行搜索(GitHub 上你还可以在语言列表中选上 Ruby)

另一个值得介绍的是 Ruby Toolbox。它可以让你按分类和热度进行搜索。不过不要仅依赖这个工具,因为 Ruby Toolbox 的作者是手工添加新的 gem 的。

Foreigner

这个 gem 可以帮你创建表的外键,它非常容易使用。你只需要简单的把它加到 Gemfile,它会为你的 migrations 增加两个方法 :add_foreign_key 和 remove_foreign_key。当然,你也可以使用这两个方法在 create_table 和 change_table 的时候添加或删除 key。

假设我们需要添加一个 key,这个 key 从 comment 表指向 posts 表。我们可以这样做:


 
 
  1. class CreateComments < ActiveRecord::Migration 
  2. def change 
  3. create_table :comments do |t| 
  4. # … t.references :post 
  5. # ... 
  6. t.foreign_key :posts 
  7. end 
  8. # … 
  9. end 
  10. end 

这些方法有一些额外的选项,例如 name,column,dependent。你可以参考文档

也许有人会认为,准确的说这个 gem 并非只适用于 Rails 的新版本,不过它确实是只有 4.2 以上的版本才支持的(其实之前已经有第三方的支持了)。总之,我认为这个 gem 属于最有用的 gem 列表之一。

项目的 GitHub 链接

letter_opener

事实上,一个简单而有用的 gem,它是保存文件夹电子邮箱的一个插件而不是发送它们。通过激活这个 gem,你必须设置 letter_opener 作为应用配置中的递交方式(例如在 config/enviroments/development.rb之中)

太好啦!现在所有发出去的消息将被存贮在 /tmp/letter_opener

文件夹里,并且新的电子邮箱被发送之后会在浏览器中预览。它简单且实际。

请链接到Github

Kaminari

该 gem 允许你很容易的创建任一复杂性的 paginators 模块。Kaminari 支持几个ORMs(ActiveRecord,Mongoid,MongoMapper)以及模板引擎(ERB,Haml,Slim)。

Kaminari 并不嵌套基础类:如 array,hash,Object 以及 ActiveRecord::Base。

让我们开始使用 Kaminari 吧,把它放在 gem 文件中,已经足够啦。某些功能变成可用之后,例如:页,每个以及对齐。现在,你可以借助于Kaminari.paginate_数组方法,来轻松地把你的 数组转换成一个分页模块,然后许多有用的分页功能将可以访问。

@paginatable_array = Kaminari.paginate_array(my_array_object).page(params[:page]).per(10)

默认的配置将被生成在 Kaminari· 配置初始化程序中。

default_per_page, max_per_page, max_pages – 这是一个简要的能被设置的选项列表。

除此之外,该分页的每个模块能被独立的配置。


 
 
  1. class User < ActiveRecord::Base  
  2. paginates_per 50 
  3. end 

如果你需要定制 paginator,你可以通过运行一个生成器来创建模板:

% rails g kaminari:views default # -e haml - if you want to use  HAML template engine.

该模板将被创建于 app/views/kaminari/ 之中,现在,你可以轻松地编辑他们。

本地化(I18n)标签,主题和友好的 urls,以及其他有用的 gem 文档选项能被找到。

请链接到 Github

CarrierWave

使用 CarrierWave 让你能够从你的 RoR 应用程序中上传任何文件。所有你需要做的事情如下:

创建一个 uploader:


 
 
  1. rails generate uploader ProductPhotoUploader 

添加一些选项:


 
 
  1. class ProductPhotoUploader < CarrierWave::Uploader::Base 
  2. include CarrierWave::MiniMagick 
  3. storage :file 
  4. def store_dir 
  5. "product_images" 
  6. end 
  7. def extension_white_list 
  8. %w(jpg jpeg gif png) 
  9. end 
  10. def filename 
  11. Digest::SHA1.hexdigest(self.read) + File.extname(original_filename) 
  12. end 
  13. end 

你已经可以使用 uploader 在存储器中保存文件了。


 
 
  1. uploader = ProductPhotoUploader.new 
  2. uploader.store!(my_file) 

CarrierWave 还允许你在临时存储、文件系统、甚至是云空间中储存文件。

你可以将 CarrierWave uploader 连接到 AR(还有其他 ORM 适配器)模型,并通过在数据库中保存一条记录来存储你的文件:


 
 
  1. class Retailer < ActiveRecord::Base 
  2. mount_uploader :logo, RetailerLogoUploader 
  3. end 
  4. retailer = Retailer.new 
  5. File.open('logo.jpg') { |f| retailer.logo = f } 
  6. retailer.save! 
  7. retailer.logo.url # => '/url/to/logo.png' 

此外,也可以改变上传图像的品质,对它进行剪裁,加密文件以及在运行中做更多的事情,在上传时 – 所有这一切都可以在文档中找到。

访问项目的 GitHub 链接

Urlify

用于将 diacritic 字符串转换为 ASCII-safe URI 字符串的一个简单且易于使用的 gem。在安装好这个 gem 之后,你可以为任何东西调用 urlify 函数,它将会立即被转换为一个等价的兼容 URI。


 
 
  1. URLify.urlify('Kj?le Test') #=> kjoele_test 

或:


 
 
  1. URLify.urlify('Kj?le Test''-') #=> kjoele-test 

访问项目的 GitHub 链接

WickedPdf

WickedPdf 是一个用于将 html 生成为 PDF 的 RoR 插件。在添加这个 gem 之后,你需要做以下步骤:

创建初始化:


 
 
  1. rails generate wicked_pdf 

注册 mine-type:

Mime::Type.register "application/pdf", :pdf

考虑到这个 gem 使用了 wkhtmltopdf,所以应该在 gem 的设置中指定其路径。

WickedPdf.config = { exe_path: '/usr/local/bin/wkhtmltopdf' }

访问该项目的 GitHub 链接

Countries

如果你面临着需要处理关于不同国家的信息的任务,这个 gem 将会提供你解决这个问题所需要的所有数据。有按国家名称和区域搜索,货币信息(符号,代码),各种形式的电话号码,坐标等功能。所有这一切需要你在安装它 之后创建一个 country 对象(或者从一个全局 helper 中获取),然后你就可以得出必要的信息了:


 
 
  1. c = ISO3166::Country.new('UA'
  2. # or to use global helper  = Country['UA'
  3. c.name      #=> "Ukraine" 
  4. c.alpha2#=> "UK" c.alpha3#=> "UKR" 
  5. c.longitude #=> "49 00 N" 
  6. c.latitude  #=> "32 00 E" 

以下为关于如何获取货币信息的代码:


 
 
  1. c.currency.code   #=> "UAH" 
  2. c.currency.symbol #=> "?" 
  3. c.currency.name   #=> "Hryvnia" 

或者检查该国是否为欧盟成员:

c.in_eu? #=> false

以下为通过名称以及货币代码搜索国家的示例:

c = ISO3166::Country.find_country_by_name('Ukraine') 
c = ISO3166::Country.find_country_by_currency('UAH')

访问该项目的 GitHub 链接

CanCanCan

这个库让你可以很方便的在 RoR 中配置权限。使用它你可以很容易的实现对特定资源的访问的限制。其便利之处在于权限的管理是跟用户分离的,而且所有的权限都存储在一个单独的地方。这就是为什么你不用再控制器、视图和数据库请求中重复地做一些事情。

这个库需要在控制器中定义一个 current_user 方法。所以你首先要对身份认证信息进行配置(这次我用到了 Devise, 不过其它的gem也可以做到)。然后. Then, generate an ability:

rails g cancan:ability

使用 :read, :create, :update 和 :destroy 这些命令来指定用户权限 (can/cannot 方法), (你可以在文档中找到更多)。


 
 
  1. class Article::Ability   
  2.   include CanCan::Ability 
  3.   def initialize(user) 
  4. case user    
  5.   when Admin      
  6.     cannot :manage, :profile      
  7.     can :read, :all        
  8.   when Moderator      
  9.     can :manage, [Apartment, RoomPrice], { lessor_id: user.id }         
  10.     can :manage, Photo, { photographer_id: user.id }      
  11.     can :manage, Lessor, { id: user.id }      
  12.     can :manage, :profile  
  13. end 
  14.   end 
  15. end 

之后,在视图中你可以使用 can? 和 cannot? 辅助方法来检查当前用户对于给定action的权限:

<% if can? :update, @article %> <%= link_to "Edit", edit_article_path(@article) %> <% end %>

你还可以使用 authorize! 来对控制器中的action进行权限认证:


 
 
  1. def show   
  2.   @article = Article.find(params[:id])   
  3.   authorize! :read, @article 
  4. end 

或者你也用到前置过滤器 load_and_authorize_resource, 它会加载资源同时尝试对其进行权限认证。

你可以使用下面的方式来catch由 CanCan::AccessDenied抛出的异常来处理有关权限认证方面的错误:


 
 
  1. class ApplicationController < ActionController::Base  
  2. rescue_from CanCan::AccessDenied do |exception|  
  3. redirect_to root_url, :alert => exception.message  
  4. end 
  5. end 

其它信息可以在 GitHub 上的文档中找到。

链接到 GitHub.

Formtastic

该 gem 提供很棒的 DSL 支持,让你可以很容易的构建出漂亮直观的基于语义的 rich form,它提供的 DSL 很容易上手:只需要在一个 Semantic_form_for 代码块里列出所有的字段,然后就可以得到一个漂亮的 form:


 
 
  1. <%= semantic_form_for @post do |f| %>  
  2. <%= f.inputs "Basic", :id => "basic" do %>  
  3. <%= f.input :title %>  
  4. <%= f.input :body %>  
  5. <% end %>  
  6. <%= f.inputs :name => "Advanced Options", :id => "advanced" do %>  
  7. <%= f.input :slug, :label => "URL Title", :hint => "Created automatically if left blank", :required => false %>  
  8. <%= f.input :section, :as => :radio %>  
  9. <%= f.input :user, :label => "Author" %>  
  10. <%= f.input :categories, :required => false %>  
  11. <%= f.input :created_at, :as => :string, :label => "Publication Date", :required => false %>  
  12. <% end %> 
  13. <%= f.actions do %> 
  14. <%= f.action :submit %>  
  15. <% end %> 
  16. <% end %> 

你也可以使用嵌套的资源:


 
 
  1. <%= semantic_form_for [@author@postdo |f| %> 

也支持嵌套的 form。你可以使用 f.semantic_form_for(Rails 风格),不过 Formtastic 风格的写法更好看一些,你可以使用 :for 选项。


 
 
  1. <%= semantic_form_for @post do |f| %> 
  2. <%= f.inputs :title, :body, :created_at %>  
  3. <%= f.inputs :first_name, :last_name, :for => :author, :name => "Author" %>  
  4. <%= f.actions %> 
  5. <% end %> 

你可以很容易的更改 input 的行为:


 
 
  1. class StringInput < Formtastic::Inputs::StringInput  
  2. def to_html 
  3. puts "this is my modified version of StringInput" 
  4. super 
  5. end 
  6. end 

基于已有的input创建自己的input:


 
 
  1. class FlexibleTextInput < Formtastic::Inputs::StringInput  
  2. def input_html_options  
  3. super.merge(:class => "flexible-text-area"
  4. end 
  5. end 

或者创建一个全新的 input 类型:


 
 
  1. class DatePickerInput  
  2. include Formtastic::Inputs::Base 
  3. def to_html 
  4. # ... 
  5. end 
  6. end 

使用方式:

:as => :date_picker

Formtastic 支持相当多的 input 类型 (select, check_boxes, radio, time_zone, datetime_select, range),基本及高级的本地化,belongs_to,has_many和has_and_belongs_to_many 的关联以及其他很多特性,具体参考文档

GitHub 的项目链接

Capistrano

该工具允许在多个远程机器上通过 ssh 的并发来执行命令。此 gem 容易使用 DSL。它使您能够定义将应用于某些角色机器的任务,并且通过网关机器来支持隧道连接。

打开 gem 之后,你必须执行:

bundle exec cap install

通过配置创建文件夹

如果你将使用不同的环境,你必须增加 STAGES 参数,例如:STAGES = local, sandbox, qa, production。运行一个 cap 脚本,使用该命令-

bundle exec cap [environments separated by gaps] [command]。例如,将部署看起来就如此的舞台环境:

bundle exec cap staging deploy

Capistrano DSL 通过 Rake 来借用。以下是该任务的一个简单例子:


 
 
  1. server 'example.com', roles: [:web, :app] 
  2. server 'example.org', roles: [:db, :workers] 
  3. desc "Report Uptimes" 
  4. task :uptime do  
  5. on roles(:all) do |host| 
  6. execute :any_command, "with args", :here, "and here" 
  7. info "Host #{host} (#{host.roles.to_a.join(', ')}):/t#{capture(:uptime)}" 
  8. end 
  9. end 

参阅所有可能的参数文档,更多关于定义任务的详细细节,请连接该插件和其他东西。

链接到Github。

好啦,我们来回顾十个最有用的 Ruby on rails gems,该是我的故事将要大结局了,我希望你能找到这个有用的信息。在我与 Evgeniy Maslov 合作而发表的“Ruby on rails 之中的 eway 支付网关集成”文章里,你将阅读更多关于 Ruby on rails。谢谢你们,再见了,亲爱的读者。


来源:51CTO

相关文章
|
5月前
|
算法 Java Go
【GoGin】(1)上手Go Gin 基于Go语言开发的Web框架,本文介绍了各种路由的配置信息;包含各场景下请求参数的基本传入接收
gin 框架中采用的路优酷是基于httprouter做的是一个高性能的 HTTP 请求路由器,适用于 Go 语言。它的设计目标是提供高效的路由匹配和低内存占用,特别适合需要高性能和简单路由的应用场景。
521 4
|
9月前
|
缓存 JavaScript 前端开发
鸿蒙5开发宝藏案例分享---Web开发优化案例分享
本文深入解读鸿蒙官方文档中的 `ArkWeb` 性能优化技巧,从预启动进程到预渲染,涵盖预下载、预连接、预取POST等八大优化策略。通过代码示例详解如何提升Web页面加载速度,助你打造流畅的HarmonyOS应用体验。内容实用,按需选用,让H5页面快到飞起!
|
9月前
|
JavaScript 前端开发 API
鸿蒙5开发宝藏案例分享---Web加载时延优化解析
本文深入解析了鸿蒙开发中Web加载完成时延的优化技巧,结合官方案例与实际代码,助你提升性能。核心内容包括:使用DevEco Profiler和DevTools定位瓶颈、四大优化方向(资源合并、接口预取、图片懒加载、任务拆解)及高频手段总结。同时提供性能优化黄金准则,如首屏资源控制在300KB内、关键接口响应≤200ms等,帮助开发者实现丝般流畅体验。
|
前端开发 JavaScript Shell
鸿蒙5开发宝藏案例分享---Web页面内点击响应时延分析
本文为鸿蒙开发者整理了Web性能优化的实战案例解析,结合官方文档深度扩展。内容涵盖点击响应时延核心指标(≤100ms)、性能分析工具链(如DevTools时间线、ArkUI Trace抓取)以及高频优化场景,包括递归函数优化、网络请求阻塞解决方案和setTimeout滥用问题等。同时提供进阶技巧,如首帧加速、透明动画陷阱规避及Web组件初始化加速,并通过优化前后Trace对比展示成果。最后总结了快速定位问题的方法与开发建议,助力开发者提升Web应用性能。
|
9月前
|
JSON 开发框架 自然语言处理
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(三)
本文主要介绍了应用开发中的三大核心内容:生命周期管理、资源限定与访问以及多语言支持。在生命周期部分,详细说明了应用和页面的生命周期函数及其触发时机,帮助开发者更好地掌控应用状态变化。资源限定与访问章节,则聚焦于资源限定词的定义、命名规则及匹配逻辑,并阐述了如何通过 `$r` 引用 JS 模块内的资源。最后,多语言支持部分讲解了如何通过 JSON 文件定义多语言资源,使用 `$t` 和 `$tc` 方法实现简单格式化与单复数格式化,为全球化应用提供便利。
335 104
|
9月前
|
JavaScript 前端开发 API
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(二)
本文介绍了HarmonyOS应用开发中的HML、CSS和JS语法。HML作为标记语言,支持数据绑定、事件处理、列表渲染等功能;CSS用于样式定义,涵盖尺寸单位、样式导入、选择器及伪类等特性;JS实现业务逻辑,包括ES6语法支持、对象属性、数据方法及事件处理。通过具体代码示例,详细解析了页面构建与交互的实现方式,为开发者提供全面的技术指导。
352 104
|
9月前
|
开发框架 编解码 JavaScript
【HarmonyOS Next之旅】基于ArkTS开发(三) -> 兼容JS的类Web开发(一)
该文档详细介绍了一个兼容JS的类Web开发范式的方舟开发框架,涵盖概述、文件组织、js标签配置及app.js等内容。框架采用HML、CSS、JavaScript三段式开发方式,支持单向数据绑定,适合中小型应用开发。文件组织部分说明了目录结构、访问规则和媒体文件格式;js标签配置包括实例名称、页面路由和窗口样式信息;app.js则描述了应用生命周期与对象管理。整体内容旨在帮助开发者快速构建基于方舟框架的应用程序。
360 102
|
11月前
|
人工智能 IDE 开发工具
JetBrains RubyMine 2025.1 发布 - 最智能的 Ruby 与 Rails IDE
JetBrains RubyMine 2025.1 (macOS, Linux, Windows) - 最智能的 Ruby 与 Rails IDE
334 30
JetBrains RubyMine 2025.1 发布 - 最智能的 Ruby 与 Rails IDE
|
关系型数据库 MySQL 数据库
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!
TIS 是一款基于Web-UI的开源大数据集成工具,通过与人大金仓Kingbase的深度整合,提供高效、灵活的实时数据集成方案。它支持增量数据监听和实时写入,兼容MySQL、PostgreSQL和Oracle模式,无需编写复杂脚本,操作简单直观,特别适合非专业开发人员使用。TIS率先实现了Kingbase CDC连接器的整合,成为业界首个开箱即用的Kingbase CDC数据同步解决方案,助力企业数字化转型。
2636 5
基于Flink CDC 开发,支持Web-UI的实时KingBase 连接器,三大模式无缝切换,效率翻倍!