🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
Haml

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

Q&A

解決済

2回答

452閲覧

rails jquery カレントページにクラスをつけたい

kaori_oka

総合スコア176

Haml

Haml(HTML abstraction markup language)は、HTML/XHTMLを効率的に記述するためのマークアップ言語および記法です。

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

jQuery

jQueryは、JavaScriptライブラリのひとつです。 簡単な記述で、JavaScriptコードを実行できるように設計されています。 2006年1月に、ジョン・レシグが発表しました。 jQueryは独特の記述法を用いており、機能のほとんどは「$関数」や「jQueryオブジェクト」のメソッドとして定義されています。

0グッド

0クリップ

投稿2019/11/12 17:05

イメージ説明
上記のような仕組みでjqueryを発火させたく、下記のようなコードを書きました。

js

1 var current_group = $(".main-header__left-box__current-group").data("group-id"); 2 $(".group").ready(function () { 3 $(".group").find(function () { 4 $(`[data-group-id=${current_group}]`).addClass("group__side_current"); 5 }); 6 });

左ナビのhaml

haml

1 .groups 2 - current_user.groups.order("created_at DESC").each do |group| 3 %div{class: "group", "data-group-id": "#{group.id}"} 4 = link_to group_messages_path(group) do 5 %p.group__group-name 6 = group.name 7 %p.group__latest-message 8 = group.show_last_message

ヘッダーのhaml

haml

1.main-header 2 .main-header__left-box 3 %h2{class: "main-header__left-box__current-group", "data-group-id": "#{@group.id}"} 4 = @group.name

すると、下記のような問題が起こり、不完全な挙動となります。

  • クリックして遷移しても変わらない。該当箇所にclassが付いていないためカレントもつかない。
  • リロードするとclassがつき、それによって該当箇所にカレントがつく。

↓動作はこんな感じです。
イメージ説明

#仮説
ajaxではなくページ遷移なので、clickメソッドではなく、.readyでDOMが読み込まれた後に、data-id一致を探しに行くような記述にした。
このreadyで読み込まれているhamlが左ナビ、ヘッダー、チャット画面、フォームで部分テンプレートとなっていて、
ファイル自体は読み込まれているが、その先の部分テンプレートまで読み込まれる前にjqueryが発火し、
data-idが付いてない状態で発火しているため、classをつけるメソッドが動作せずこのような顛末になったのではないかと思っています。

検索すると、こういった読み込み原因っぽい挙動の解消についてはclickで発火と書かれていることが多いのですが、
非同期ではなくページ遷移なので、clickではカレントの実装ができませんでした。

検索のヒントでも良いので、ご意見伺えればと思います!

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答2

0

自己解決

①app/assets/javascripts/application.js
このファイルから下記を削除

js

1//= require turbolinks

②data-idの致で判定

js

1 var a = $(".main-header__left-box__current-group").data("group-id") 2 $(".group").each(function (i, ele) { 3 if ($(ele).data("group-id") === a) { 4 $(this).addClass("group__side_current") 5 } else { 6 $(this).removeClass("group__side_current") 7 } 8 }); 9

問題は①turbolinksらしく、
読み込みを早くするようなものらしいですが、それが悪さをしていたようで
動作が不安定だったようです。

投稿2019/11/14 15:05

編集2019/11/14 15:56
kaori_oka

総合スコア176

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

0

var current_group = $(".main-header__left-box__current-group").data("group-id");

$(".group").ready(function () { の外にあるので、domができる前に実行されてcurrent_groupちゃんと取れていないのでは?という予想です(外してたらごめんなさい)

投稿2019/11/13 12:40

8zca

総合スコア559

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kaori_oka

2019/11/14 15:06

ありがとうございます! 試してみましたが、結果は変わりませんでした。 詳しい人に教えていただき、解決しましたのでご参照いただければと思います。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.36%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問