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

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

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

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

JavaScript

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

jQuery

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

2回答

1044閲覧

横にタブをスライドするCSSがうまくいかない

tomtom1

総合スコア168

Ruby on Rails

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

JavaScript

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

jQuery

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

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2020/02/11 10:12

###実現したいこと
タブをクリックすると、横にスーッとスライドするようにしたいです。
タブをクリックしても、反応が得られません。
$("#tab1").click(moveToFirst);のあたりが怪しいと思っていますが、わからずにいます。

また、他のjsはうまく反応を得られています。

###コード

HTML

1<div id="wrap"> 2 <div id="tab1" class="tab selected">Tab 1</div> 3 <div id="tab2" class="tab">Tab 2</div> 4 5 <div id="container"> 6 <div id="slide" class=""> 7 <div id="first" class="box">1タブ内容</div> 8 <div id="second" class="box">2タブ内容</div> 9 </div> 10 </div> 11</div>

js

1//= require activestorage 2//= require turbolinks 3//= require_tree . 4//= require jquery 5//= require jquery_ujs 6$("#tab1").click(moveToFirst); 7$("#tab2").click(moveToSecond); 8 9function moveToFirst() { 10 $("#slide").attr('class', 'move-to-first'); 11 $(".tab").attr('class', 'tab'); 12 $("#tab1").attr('class', 'tab selected'); 13} 14 15function moveToSecond() { 16 $("#slide").attr('class', 'move-to-second'); 17 $(".tab").attr('class', 'tab'); 18 $("#tab2").attr('class', 'tab selected'); 19}

css

1.tab { 2 height: 40px; 3 width: 100px; 4} 5 6.selected { 7 background-color: black; 8} 9 10#container { 11 position: relative; 12 overflow: hidden; 13 clear: left; 14} 15 16.box { 17 display: inline-block; 18 white-space: nowrap; 19 position: absolute; 20 width: 400px; 21 height: 200px; 22} 23 24#first { 25 top: 0px; 26 left: 0px; 27} 28 29#second { 30 top: 0px; 31 left: 400px; 32} 33 34#slide { 35 transition: transform 1s ease-in-out 0s; 36 -moz-transition: -moz-transform 1s ease-in-out 0s; 37 -webkit-transition: -webkit-transform 1s ease-in-out 0s; 38} 39.move-to-first { 40 transform: translateX(0px); 41 -moz-transform: translateX(0px); 42 -webkit-transform: translateX(0px); 43} 44.move-to-second { 45 transform: translateX(-400px); 46 -moz-transform: translateX(-400px); 47 -webkit-transform: translateX(-400px); 48} 49 50 51

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

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

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

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

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

guest

回答2

0

position: absolute;で子要素がフロートするので、container の高さが 0 になっていて、overflow: hidden;で子要素が隠れてしまってます。

containerのサイズを適切に設定するといいでしょう。

css

1#container { 2 position: relative; 3 overflow: hidden; 4 clear: left; 5 width: 400px; /*追加*/ 6 height: 200px; /*追加*/ 7}

投稿2020/02/11 11:13

編集2020/02/11 11:20
hatena19

総合スコア33715

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

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

tomtom1

2020/02/12 09:18

ご回答ありがとうございます!今回、Turbolinksによる影響でした! しかしながら、おっしゃる通り、CSSに不具合がありました。 新たに質問を作成しましたので、ご確認頂ければ幸いです。 https://teratail.com/questions/240948?modal=q-comp
tomtom1

2020/02/12 14:30

先ほどご指摘頂いた内容を完全に理解しました。そういうことだったのですね。ありがとうございます。 本内容の続きで、「要素の高さを中のフロートした子要素の高さに合わせたい」というタイトルで新たに質問を発行しましたので、よろしければご確認お願いします。 https://teratail.com/questions/240998?modal=q-comp
guest

0

ベストアンサー

Turbolinksによる影響は考えられないでしょうか?

$(document).on('turbolinks:load', function() { //ここにJqueryのコードを記載する。 });

投稿2020/02/11 11:08

no1knows

総合スコア3365

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

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

tomtom1

2020/02/12 09:19

そうでした、ご指摘ありがとうございます。無事解決しました!
no1knows

2020/02/12 10:26

それは良かったです!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問