锦囊妙计-前端篇

Lose your first 50 games as quickly as possible. - 围棋谚语

Build your first 50 Rails apps as quickly as possible. - 造样造句

Bootstrap

Bootstrap是目前最流行的前端设计框架,让开发者也可以很轻松的进行网页排版,也很有多现成的Theme可以套用。要在Rails使用Bootstrap,请安装bootstrap-sass

如果搭配分页套件kaminari的话,执行rails generate kaminari:views bootstrap3就会产生对应的kaminari样板。

进一步可以参考Integrating Rails and Bootstrap这一系列文章。

Font Awesome

即将推出的 Bootstrap 4 将会移除 Glyphicons,所以目前大家推荐使用 Font-Awesome

Rails 可以安装 https://github.com/bokmann/font-awesome-rails 这个 gem

表单

除了用Rails内建的表单Helper,也有一些提供表单设计更方便的套件:

select2 厉害的下拉选单

https://github.com/argerim/select2-rails

漂亮的 Date/Time 输入和输出

表单输入

调整显示格式

  1. Date::DATE_FORMATS[:short] = "%Y/%m/%d"
  2. Time::DATE_FORMATS[:short] = "%Y/%m/%d %H:%M"

Admin 接口

管理员后台除了自己盖,有一些 gem 可以很快速的盖起来,例如这两套:

缺点:想要扩充或修改的时候,会碰到限制和麻烦。

如何画图表

常用图表包括 Line chart、Pie chart、Column chart、Bar chart 等等,最常见使用 Google ChartsHighchartsD3.js

搭配 Rails 的话,可以安装 https://github.com/ankane/chartkick 这一套最简单,但功能较少。或是笔者推荐使用 Chart.js

自订 URL 网址

可以让使用者自订,或是乱数产生当作 URLhttp://railscasts.com/episodes/63-model-name-in-url-revised

范例:

Nested Form (1-to-many)

1 对 1 的表单

使用 Rails 内建的 fields_for 就可以完成,参考 https://ihower.tw/rails4/restful-practices.html

1 对多的表单

如果知道固定N笔,作法同上。但如果需要可以动态加减数量,则需要 JavaScript 协助动态增减字段。

可以使用 https://github.com/ncri/nested_form_fields gem (注意 Strong Parameter,这个 gem 的 README 没提到) 或 https://github.com/nathanvda/cocoon另外参考 http://api.rubyonrails.org/classes/ActiveRecord/NestedAttributes/ClassMethods.html 的 reject_if 用法

范例 Example Code: https://github.com/ihower/rails-exercise-ac3/tree/nested_form

Recapache

  • Recaptcha 是做 captcha 最简单快速的方式。