質問をすることでしか得られない、回答やアドバイスがある。

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

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

1回答

1055閲覧

特定のhtmlファイルのみでjsを発火させたい。

shimpext

総合スコア5

Ruby on Rails

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

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/04/12 07:57

編集2020/04/12 08:04

前提・実現したいこと

index.html.haml内のみでjsファイルを適用したいです。
ご教示お願い致します。

発生している問題・エラーメッセージ

他のページに遷移した際もjsファイルが読み込まれてしまい、
エラーが発生してしまいます。

Uncaught TypeError: Cannot read property 'classList' of undefined at switchImage

該当のソースコード

var elInner, duration, defaultIndex, switchImage; elInner = document.getElementsByClassName('wrapper__photo__image'); duration = 5000; defaultIndex = 0; switchImage = function(next) { var current = next ? (next - 1) : elInner.length - 1; elInner[current].classList.remove('is-visible'); elInner[next].classList.add('is-visible'); next = (++next < elInner.length) ? next : 0; setTimeout(switchImage.bind(this, next), duration); }; window.onload = switchImage.bind(this, defaultIndex);

試したこと

下記URLの情報を元に5行目にif文を使ってみましたが、反応がしませんでした。
http://tokidoki-web.com/2013/02/%E3%80%8Ejquery%E3%81%A7%E7%89%B9%E5%AE%9A%E3%81%AEurl%E3%81%8C%E4%B8%80%E8%87%B4%E3%81%97%E3%81%9F%E3%82%89%E5%87%A6%E7%90%86%E3%81%97%E3%81%A6%E3%82%84%E3%82%93%E3%82%88%E3%80%8F/

var elInner, duration, defaultIndex, switchImage; elInner = document.getElementsByClassName('wrapper__photo__image'); duration = 5000; defaultIndex = 0; if(document.URL.indexOf("index.html.haml")) { switchImage = function(next) { var current = next ? (next - 1) : elInner.length - 1; elInner[current].classList.remove('is-visible'); elInner[next].classList.add('is-visible'); next = (++next < elInner.length) ? next : 0; setTimeout(switchImage.bind(this, next), duration)}; }; window.onload = switchImage.bind(this, defaultIndex);

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

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

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

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

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

guest

回答1

0

ベストアンサー

やり方はいろいろとあるのですが、全体のHTMLがわからないのでとりあえずwrapper__photo__imageクラスがあれば実行させる感じとかはいかがでしょうか?

var elInner, duration, defaultIndex, switchImage; elInner = document.getElementsByClassName('wrapper__photo__image'); duration = 5000; defaultIndex = 0; if(elInner.length) { switchImage = function(next) { : }; };

まぁ、その他Turbolinksを利用しているのか、他のページでもwrapper__photo__imageがあるのかなどで検討する必要がありますね。

あとは、アクション名controller.action_nameや、コントローラー名controller.controller_nameで条件分岐してjsを読み込ませたり・・・


細かいところはおまかせしますが、変数elInnerがあれば実行させるという形ですね。

投稿2020/04/12 08:34

編集2020/04/12 09:21
no1knows

総合スコア3365

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

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

shimpext

2020/04/12 09:47 編集

ご回答ありがとうございます。 htmlファイルを添付いたします。 4枚画像を登録しており、一定時間で切り替わるという処理をさせようと思っています。 下記のようにjsファイルを修正しましたが、1行目でUncaught ReferenceError: elInner is not definedが起きました。書き方が間違っていますでしょうか?何度も質問してしまい申し訳ございません。 jsファイル ``` if(elInner.length) { switchImage = function(next) { var elInner, duration, defaultIndex, switchImage; elInner = document.getElementsByClassName('wrapper__photo__image'); duration = 5000; defaultIndex = 0; switchImage = function(next) { var current = next ? (next - 1) : elInner.length - 1; elInner[current].classList.remove('is-visible'); elInner[next].classList.add('is-visible'); next = (++next < elInner.length) ? next : 0; setTimeout(switchImage.bind(this, next), duration); } }; }; ```
no1knows

2020/04/12 09:21

修正しました!
shimpext

2020/04/12 10:18

ご返信ありがとうございます。 下記のように修正し、エラーは出ませんが、発火もされなくなってしまいました。何度も教えていただいているのに解決できず、申し訳ございません。 問題点がありましたら、教えていただきたいです。 var elInner, duration, defaultIndex, switchImage; elInner = document.getElementsByClassName('wrapper__photo__image'); duration = 5000; defaultIndex = 0; if(elInner.length) { switchImage = function(next) { var current = next ? (next - 1) : elInner.length - 1; elInner[current].classList.remove('is-visible'); elInner[next].classList.add('is-visible'); next = (++next < elInner.length) ? next : 0; setTimeout(switchImage.bind(this, next), duration) }; }; 下記のコードもつけてみましたが、それだとエラーが出ます。 window.onload = switchImage.bind(this, defaultIndex);
no1knows

2020/04/12 16:59

Turbolinksを利用しているなら $(document).on('turbolinks:load', function() { }); でうまくいきましたか?
shimpext

2020/04/12 17:40

ご返信ありがとうございます! うまくいきました! 本当にありがとうございました!!!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問