<?xml version="1.0" encoding="UTF-8"?>
<rss version="2.0">
  <channel>
    <title>gschen (justin_cn)</title>
    <link>https://ruby-china.org/gschen</link>
    <description>It never rains but it pours.</description>
    <language>en-us</language>
    <item>
      <title>RailsAdmin 如何实现自定义操作</title>
      <description>&lt;h2 id="前言"&gt;前言&lt;/h2&gt;
&lt;p&gt;做过 Ruby 开发或者更准确的说 Ruby on Rails 开发的同学，对 RailsAdmin 一定不会陌生。RailsAdmin 可以快速的帮助您构建后台管理系统。丰富的 gem 集成以及便捷的搭建使得 RailsAdmin 成为 web 开发中必不可少的组成部分。另外通过 RailsAdmin 你也可以非常强烈的感受到敏捷开发的魅力所在，以及如何快速的帮助客户解决问题，快速搭建原型系统，满足客户需求。&lt;/p&gt;

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

&lt;p&gt;本文主要介绍在 RailsAdmin 中如何自定义操作 (custom action)，由于国内 ruby 及 rails 中文资料不是特别丰富，如果您从事 ruby 开发，那么本文可能对您会有一定的帮助。&lt;/p&gt;
&lt;h2 id="总体思路"&gt;总体思路&lt;/h2&gt;
&lt;p&gt;对于教程，我个人比较倾向的一种思路是，先介绍总体流程，让用户对其有个整体印象，然后详细的介绍每一步。这种方式使得用户能够非常轻松的接受，遇到问题如果出现问题也能很好的定位问题出现在哪一阶段。&lt;/p&gt;

&lt;p&gt;我们如何在 RailsAdmin 中实现自定义操作呢？
主要有以下几个关键步骤：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;定义和实现我们的操作并注册到 RailsAdmin，让 RailsAdmin 能够知道该操作的存在；&lt;/li&gt;
&lt;li&gt;定义该操作的前端显示页面；&lt;/li&gt;
&lt;li&gt;在 RailsAdmin 配置文件中，使用该操作；&lt;/li&gt;
&lt;/ul&gt;

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

&lt;p&gt;以下描述将基于下述基本约定：&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;当前开发目录为 ROOT;&lt;/li&gt;
&lt;li&gt;自定义操作名称为 demo;&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;本文我们实现的自定义操作 demo 达到的目标是：在 member scope 中添加 demo action，点击 demo，前端显示'hello,world'。&lt;/p&gt;
&lt;h2 id="step0"&gt;step0&lt;/h2&gt;
&lt;p&gt;在 Rails 开发中，无时无刻不体现着“约定优于配置”。那么我们自定义操作应该放在哪儿呢？文件如何命名？答案就是如下所示：
文件路径为 ROOT/lib/rails_admin/；
文件的名称即为操作名称即 demo.rb;&lt;/p&gt;

&lt;p&gt;所以接下来我们将在该路径创建我们的自定义操作文件。&lt;/p&gt;
&lt;pre class="highlight shell"&gt;&lt;code&gt;&lt;span class="nb"&gt;touch &lt;/span&gt;ROOT/lib/rails_admin/demo.rb
&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;接下来我们将介绍一个非常重要的概念就是 action scope。你的操作应用到什么地方？
RailsAdmin 中 action scope 主要有三种，分别是：root, collection, member。&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;root 顾名思义就是根操作，和 dashboard 处于一个层级；&lt;/li&gt;
&lt;li&gt;collection 针对记录集合的操作；&lt;/li&gt;
&lt;li&gt;member 针对某条具体的记录的操作；&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;本文我们自定义操作的 scope 就是 collection。接下来我们就具体介绍自定义操作的实现。&lt;/p&gt;
&lt;pre class="highlight ruby"&gt;&lt;code&gt;&lt;span class="nb"&gt;require&lt;/span&gt; &lt;span class="s1"&gt;'rails_admin/config/actions/base'&lt;/span&gt;

&lt;span class="k"&gt;module&lt;/span&gt; &lt;span class="nn"&gt;RailsAdmin&lt;/span&gt;
  &lt;span class="k"&gt;class&lt;/span&gt; &lt;span class="nc"&gt;Demo&lt;/span&gt; &lt;span class="o"&gt;&amp;lt;&lt;/span&gt; &lt;span class="no"&gt;RailsAdmin&lt;/span&gt;&lt;span class="o"&gt;::&lt;/span&gt;&lt;span class="no"&gt;Config&lt;/span&gt;&lt;span class="o"&gt;::&lt;/span&gt;&lt;span class="no"&gt;Actions&lt;/span&gt;&lt;span class="o"&gt;::&lt;/span&gt;&lt;span class="no"&gt;Base&lt;/span&gt;    &lt;span class="c1"&gt;#Demo操作继承Base&lt;/span&gt;
    &lt;span class="no"&gt;RailsAdmin&lt;/span&gt;&lt;span class="o"&gt;::&lt;/span&gt;&lt;span class="no"&gt;Config&lt;/span&gt;&lt;span class="o"&gt;::&lt;/span&gt;&lt;span class="no"&gt;Actions&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;register&lt;/span&gt;&lt;span class="p"&gt;(&lt;/span&gt;&lt;span class="nb"&gt;self&lt;/span&gt;&lt;span class="p"&gt;)&lt;/span&gt;      &lt;span class="c1"&gt;#RailsAdmin中注册demo操作&lt;/span&gt;

    &lt;span class="n"&gt;register_instance_option&lt;/span&gt; &lt;span class="ss"&gt;:member&lt;/span&gt; &lt;span class="k"&gt;do&lt;/span&gt;             &lt;span class="c1"&gt;#设置其action scope为member&lt;/span&gt;
      &lt;span class="kp"&gt;true&lt;/span&gt;
    &lt;span class="k"&gt;end&lt;/span&gt;

  &lt;span class="k"&gt;end&lt;/span&gt;
&lt;span class="k"&gt;end&lt;/span&gt;

&lt;/code&gt;&lt;/pre&gt;&lt;h2 id="step1"&gt;step1&lt;/h2&gt;
&lt;p&gt;我们在什么地方定义我们的前端显示文件？答案就是：
ROOT/app/view/rails_admin/main/demo.html.erb
我们的前端模板可以使用 erb, haml, slim 等，至于模板语言如何使用，这并非本文描述的重点。
所以我们的前端文件显示非常的简单，直接打印"hello,world"即可。。&lt;/p&gt;
&lt;pre class="highlight html"&gt;&lt;code&gt;&lt;span class="c"&gt;&amp;lt;!-- File: demo.html.erb --&amp;gt;&lt;/span&gt;
&lt;span class="nt"&gt;&amp;lt;p&amp;gt;&lt;/span&gt; hello, world! &lt;span class="nt"&gt;&amp;lt;/p&amp;gt;&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;h2 id="step2"&gt;step2&lt;/h2&gt;
&lt;p&gt;至此，我们的自定义操作的定义，以及前端显示都已经完成，接下来就是如何使用该自定义操作了。&lt;/p&gt;

&lt;p&gt;我们打开 ROOT/config/initializers/rails_admin.rb 文件。&lt;/p&gt;

&lt;ul&gt;
&lt;li&gt;引入我们的自定义操作文件；&lt;/li&gt;
&lt;li&gt;在哪个 model 中使用该操作；&lt;/li&gt;
&lt;/ul&gt;

&lt;p&gt;如何引入？&lt;/p&gt;
&lt;pre class="highlight ruby"&gt;&lt;code&gt;&lt;span class="nb"&gt;require&lt;/span&gt; &lt;span class="s1"&gt;'rails_admin/demo'&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;
&lt;p&gt;如何使用 demo action？&lt;/p&gt;

&lt;p&gt;我们希望 demo 操作只应用于 User Model 中，所以在 config.actions 中配置。&lt;/p&gt;
&lt;pre class="highlight ruby"&gt;&lt;code&gt;&lt;span class="n"&gt;config&lt;/span&gt;&lt;span class="p"&gt;.&lt;/span&gt;&lt;span class="nf"&gt;actions&lt;/span&gt; &lt;span class="k"&gt;do&lt;/span&gt;
    &lt;span class="n"&gt;demo&lt;/span&gt; &lt;span class="k"&gt;do&lt;/span&gt;
        &lt;span class="n"&gt;only&lt;/span&gt; &lt;span class="s1"&gt;'User'&lt;/span&gt;
    &lt;span class="k"&gt;end&lt;/span&gt;
&lt;span class="k"&gt;end&lt;/span&gt;
&lt;/code&gt;&lt;/pre&gt;&lt;h2 id="总结"&gt;总结&lt;/h2&gt;
&lt;p&gt;本文主要介绍了如何在 RailsAdmin 中创建自定义操作，先从总体上描述了大致思路，然后逐步的介绍其实现细节。RailsAdmin 已经成为 web 开发中必不可少的组成部分，通过自定义操作扩展其功能已是不可避免，所以本文具有一定的参考借鉴价值。&lt;/p&gt;

&lt;p&gt;本文介绍的只是简单的自定义操作，可以帮助您快速的上手，后续博客将逐步深入的介绍更多的自定义操作用法。&lt;/p&gt;
&lt;h2 id="引用"&gt;引用&lt;/h2&gt;
&lt;ul&gt;
&lt;li&gt;&lt;a href="http://blog.endpoint.com/2012/01/import-railsadmin.html" rel="nofollow" target="_blank" title=""&gt;http://blog.endpoint.com/2012/01/import-railsadmin.html&lt;/a&gt;&lt;/li&gt;
&lt;li&gt;&lt;a href="http://blog.endpoint.com/2012/03/railsadmin-custom-action-case-study.html" rel="nofollow" target="_blank" title=""&gt;http://blog.endpoint.com/2012/03/railsadmin-custom-action-case-study.html&lt;/a&gt;&lt;/li&gt;
&lt;/ul&gt;</description>
      <author>gschen</author>
      <pubDate>Fri, 14 Nov 2014 09:14:06 +0800</pubDate>
      <link>https://ruby-china.org/topics/22674</link>
      <guid>https://ruby-china.org/topics/22674</guid>
    </item>
  </channel>
</rss>
