2016-11-07 22 views
1

私は次のルートがありますなぜcurrent_pageですか?完全に管理されたリソース上で実行しているときに `no route error`を返しますか?

resources :profiles do 
    member do 
     patch :speed_rating 
     patch :dribbling_rating 
     patch :passing_rating 
     patch :tackling_rating 
     post :favorite 
     post :unfavorite 
    end 
    collection do 
     get :autocomplete 
    end 
    end 

私が興味を持って次のルート生成します

<% if current_page?(controller: "profiles", action: "show")%> 
     <div id="page-wrapper" class="gray-bg"> 
    <% else %> 
     <div id="page-wrapper" class="image-bg"> 
    <% end %> 

ときI:私のapplication.html.erb

# truncated for brevity 
profiles_path GET /profiles(.:format) profiles#index 

profile_path GET /profiles/:id(.:format) profiles#show 

を、私はこれを持っています私のProfiles#Showに行ってください。それはうまくいきますが、Profiles#Index(別名root_path)に行くと、私は別のものを手に入れます:レコードの

Started GET "/" for ::1 at 2016-11-07 16:52:01 -0500 
    User Load (1.9ms) SELECT "users".* FROM "users" WHERE "users"."id" = $1 ORDER BY "users"."id" ASC LIMIT $2 [["id", 7], ["LIMIT", 1]] 
Processing by ProfilesController#index as HTML 
    Role Load (4.8ms) SELECT "roles".* FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'admin') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    Role Load (12.9ms) SELECT "roles".* FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'coach') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    Role Load (6.7ms) SELECT "roles".* FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'player') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    (4.9ms) SELECT COUNT(*) FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'admin') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL)) OR ((roles.name = 'coach') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    CACHE (0.0ms) SELECT "roles".* FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'player') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    (2.6ms) SELECT COUNT(*) FROM "roles" INNER JOIN "users_roles" ON "roles"."id" = "users_roles"."role_id" WHERE "users_roles"."user_id" = $1 AND (((roles.name = 'coach') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL)) OR ((roles.name = 'admin') AND (roles.resource_type IS NULL) AND (roles.resource_id IS NULL))) [["user_id", 7]] 
    Profile Search (23.5ms) curl http://localhost:9200/profiles_development/_search?pretty -d '{"query":{"match_all":{}},"size":1000,"from":0,"timeout":"11s","_source":false}' 
    Tournament Load (2.7ms) SELECT "tournaments".* FROM "tournaments" ORDER BY "tournaments"."id" ASC LIMIT $1 [["LIMIT", 1]] 
    Rendering profiles/index.html.erb within layouts/application 
    Profile Load (1.7ms) SELECT "profiles".* FROM "profiles" WHERE "profiles"."id" IN (14, 22, 12, 21, 9, 5, 4, 15, 6, 7, 16, 18, 13, 23, 17) 
Read fragment views//profiles/14-20161105042425134917/profiles/22-20161106175803133611/profiles/12-20161101225114614189/profiles/21-20161103035514173735/profiles/9-20161104221706306433/profiles/5-20161105043153971213/profiles/4-20161103035528589634/profiles/15-20161029013919242687/profiles/6-20161105043216951643/profiles/7-20161101001052922220/profiles/16-20161029020526832889/profiles/18-20161101223838805685/profiles/13-20161104221749051281/profiles/23-20161104062851335443/profiles/17-20161105043606243802/af785066fd895798884eea54748241db (0.1ms) 
    Rendered profiles/index.html.erb within layouts/application (12.5ms) 
Completed 500 Internal Server Error in 379ms (ActiveRecord: 36.4ms) 


ActionController::UrlGenerationError - No route matches {:action=>"show", :controller=>"profiles"}: 

編集1

、問題なく、次の作品:

<% if (controller_name.eql? "profiles") && (action_name.eql? "show") %> 
+0

:コントローラ=> "プロファイル" "プロファイル"ではありませんか? –

+0

@EricDuminilです。私の悪い。私は 'current_page?(controller:" profile ")'を使用し、誤ったログ出力を貼り付けた場合、重要かどうかをテストしていました。今修正されました。また、記録のために、それは重要ではなかった。どちらもうまくいかなかった。 – marcamillion

答えて

0

あなたはcurrent_page?source codeを見てみた場合、あなたはそれがurl_forを使用して実現するだろう、これURLを作成し、アドレスバーに表示されているものと一致する有効なオプションが実際に必要です。

url_for(controller: "profiles", action: "show")は、:idなしでそのルートを見つけることができません。 current_page?(controller: "profiles", action: "show", id: 1)を使用しようとすると、エラーが発生しないことがわかります。のような他のクエリ文字列パラメータを含め、完全な一致をテストするために設計されていますので、

current_pageがこの仕事のためにあなたの最良の選択肢ではありません:あなたの特定のケースで

# http://www.example.com/shop/checkout?order=desc&page=1 
current_page?(controller: 'shop', action: 'checkout', order: 'desc', page: '1') 

、あなたが一致することを希望しますshowアクションをレンダリングするページ。私はあなたが編集1であなたが提示した解決策が適していると思います。あなたがそれをきれいにしたいなら、いつでも自分のヘルパーで包み込むことができます。

関連する問題