忍者ブログ
ブログツール、2007/11/06作成
[3] [4] [5] [6] [7] [8
×

[PR]上記の広告は3ヶ月以上新規記事投稿のないブログに表示されています。新しい記事を書く事で広告が消えます。

よく忘れちゃうのでメモ。

フォームヘルパのform_tagで、
<%= form_tag :contorller=>'hoge', :action=>'fuga' %>
</form>
とやると閉じタグが気持ち悪いので、do~endでやるわけだけど、そのときの注意

  1. <%= %>はやっちゃだめ。
  2. form_tag()の括弧は省略するとハマる。オプションの{}ブレースも省略しない方が吉。

こんな感じ
<% form_tag( {:controller=>'hoge', :action=>'fuga', :piyo_id=>@piyo} ) do %>

<% end %>
PR
AR.findの:includeオプションでハマる。

これまであまりにパフォーマンス無視で作ってきたのを反省して、SQLの発行回数を減らすために:includeオプションを多用してみた。
そしたら、Modelクラスで:order宣言しているときにSQLエラー発生。
エラーをみるに、order指定しているカラムは使えん、とのこと。

はじめ、:order指定するためのカラム名を安直にorderにしてしまったため、SQLの予約語とかぶったんだと思い、シングルクオートで囲んだりいろいろやってみるもいずれも失敗。
さらにカラム名をdisplay_orderとかにしてみてもだめ。

結局、回避策はModelクラスの :orderオプションにテーブル名のプレフィックスをつけることでした。orz
こんな感じ

class Hoge
has_many :fugas, :order="fugas.display_order"
end

class Fuga
belogns_to :hoge
end
こうしたものの、多重has_many関連の途中だと失敗しちゃう。
例:
class Hoge
has_many :fugas, :order=>'fugas.desplay_order'
end

class Fuga
belogns_to :hoge
has_many :piyos, :order=>'piyos.display_order'
end

class Piyo
belongs_to :Fuga
end
このとき、
コントローラで
hoge = Hoge.find(id, :include=>{:fuga=>:piyo})
とやったときは問題ない。
fuga = Fuga(id, :include=>:piyo)
とやったときもOK。
ところが、
hoge = Hoge.find(id, :include=>{:fuga=>:piyo})
とやって、
fuga = hoge.fugas.find(fuga_id, :include=>:piyo)
とやるとSQLエラーが。

ARのソースでも読めばわかるんだと思うけど、なかなかそこまでの根性が入りまへん。
あきらめて結局、
fuga = Fuga.find(fuga_id, :include=>:piyo)
とやってしまった。

とほほ。
railsを使っていて、アクションのパラメータ(paramsで渡されるやつ)にハッシュや配列を使いたいときがある。
これまでどうやって使えばいいのかわからないので適当に回避していたけど、ようやくやり方がわかった。

わかってみれば実に簡単。(^^;
Viewファイルのinput系ヘルパを使うときの第一引数にそのまんま書いてやると反映することが判明。

:hoge_array.rhtml
<%= hidden_field_tag "hoge[]", "fuga1" >
<%= hidden_field_tag "hoge[]", "fuga2">

params[:hoge] ->["fuga1", "fuga2"]

とまあ、こんな感じ。

hidden_field_tagをcheck_box_tagにしてやれば、選択項目のみを配列で取得できるようになる。
まあ、なんて便利な。


ハッシュがほしいときにはこうする。
:hoge_hash.rhtml
<%= hidden_field_tag "hoge[fuga]", "FUGA1" >
<%= hidden_field_tag "hoge[piyo]", "PIYO2">

params[:hoge] -> {:fuga=>'FUGA1", :piyo=>"PIYO2"}
ついめ~じ
ブログ内検索
フリーエリア
サニーカメラ
Powered by Ninja Blog    template by Temp* factory    icon by MiniaureType

忍者ブログ [PR]