Rails RailsAdmin 如何实现自定义操作

gschen · 2014年11月14日 · 2182 次阅读

前言

做过 Ruby 开发或者更准确的说 Ruby on Rails 开发的同学,对 RailsAdmin 一定不会陌生。RailsAdmin 可以快速的帮助您构建后台管理系统。丰富的 gem 集成以及便捷的搭建使得 RailsAdmin 成为 web 开发中必不可少的组成部分。另外通过 RailsAdmin 你也可以非常强烈的感受到敏捷开发的魅力所在,以及如何快速的帮助客户解决问题,快速搭建原型系统,满足客户需求。

RailsAdmin 固然已经非常的便捷,但有时不能满足我们的需求,此时就需要我们自定义一些操作,扩展 RailsAdmin 的功能。

本文主要介绍在 RailsAdmin 中如何自定义操作 (custom action),由于国内 ruby 及 rails 中文资料不是特别丰富,如果您从事 ruby 开发,那么本文可能对您会有一定的帮助。

总体思路

对于教程,我个人比较倾向的一种思路是,先介绍总体流程,让用户对其有个整体印象,然后详细的介绍每一步。这种方式使得用户能够非常轻松的接受,遇到问题如果出现问题也能很好的定位问题出现在哪一阶段。

我们如何在 RailsAdmin 中实现自定义操作呢? 主要有以下几个关键步骤:

  • 定义和实现我们的操作并注册到 RailsAdmin,让 RailsAdmin 能够知道该操作的存在;
  • 定义该操作的前端显示页面;
  • 在 RailsAdmin 配置文件中,使用该操作;

通过上面的三个关键操作就可以完成我们的自定义操作了。接下来我们将介绍每一步的具体实现细节。

以下描述将基于下述基本约定:

  • 当前开发目录为 ROOT;
  • 自定义操作名称为 demo;

本文我们实现的自定义操作 demo 达到的目标是:在 member scope 中添加 demo action,点击 demo,前端显示'hello,world'。

step0

在 Rails 开发中,无时无刻不体现着“约定优于配置”。那么我们自定义操作应该放在哪儿呢?文件如何命名?答案就是如下所示: 文件路径为 ROOT/lib/rails_admin/; 文件的名称即为操作名称即 demo.rb;

所以接下来我们将在该路径创建我们的自定义操作文件。

touch ROOT/lib/rails_admin/demo.rb

接下来我们将介绍一个非常重要的概念就是 action scope。你的操作应用到什么地方? RailsAdmin 中 action scope 主要有三种,分别是:root, collection, member。

  • root 顾名思义就是根操作,和 dashboard 处于一个层级;
  • collection 针对记录集合的操作;
  • member 针对某条具体的记录的操作;

本文我们自定义操作的 scope 就是 collection。接下来我们就具体介绍自定义操作的实现。

require 'rails_admin/config/actions/base'

module RailsAdmin
  class Demo < RailsAdmin::Config::Actions::Base    #Demo操作继承Base
    RailsAdmin::Config::Actions.register(self)      #RailsAdmin中注册demo操作

    register_instance_option :member do             #设置其action scope为member
      true
    end

  end
end

step1

我们在什么地方定义我们的前端显示文件?答案就是: ROOT/app/view/rails_admin/main/demo.html.erb 我们的前端模板可以使用 erb, haml, slim 等,至于模板语言如何使用,这并非本文描述的重点。 所以我们的前端文件显示非常的简单,直接打印"hello,world"即可。。

<!-- File: demo.html.erb -->
<p> hello, world! </p>

step2

至此,我们的自定义操作的定义,以及前端显示都已经完成,接下来就是如何使用该自定义操作了。

我们打开 ROOT/config/initializers/rails_admin.rb 文件。

  • 引入我们的自定义操作文件;
  • 在哪个 model 中使用该操作;

如何引入?

require 'rails_admin/demo'

如何使用 demo action?

我们希望 demo 操作只应用于 User Model 中,所以在 config.actions 中配置。

config.actions do
    demo do
        only 'User'
    end
end

总结

本文主要介绍了如何在 RailsAdmin 中创建自定义操作,先从总体上描述了大致思路,然后逐步的介绍其实现细节。RailsAdmin 已经成为 web 开发中必不可少的组成部分,通过自定义操作扩展其功能已是不可避免,所以本文具有一定的参考借鉴价值。

本文介绍的只是简单的自定义操作,可以帮助您快速的上手,后续博客将逐步深入的介绍更多的自定义操作用法。

引用

暂无回复。
需要 登录 后方可回复, 如果你还没有账号请 注册新账号