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

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

新規登録して質問してみよう
ただいま回答率
87.20%
CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

解決済

javascriptで左右見切れているカルーセルの実装

AN3000
AN3000

総合スコア34

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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

2回答

0評価

1クリップ

231閲覧

投稿2022/04/26 06:07

編集2022/04/27 14:43

表題の通り、javascriptで左右見切れているカルーセルの実装をしているのですが、どうプログラムしていいかわかりません。

下記にイメージ画像を貼っておきます。
イメージ説明

ネットで検索してでてくるのはjQueryばかりでjavascriptでの実装の情報は少ないように感じましたので、こちらで質問させていただきました。

ここからどうコーディングしていくか教えていただけないでしょうか。

html

<div class="slider-area"> <ul class="boxslider"> <li>box1</li> <li>box2</li> <li>box3</li> <li>box4</li> <li>box5</li> </ul> </div> <button id="return">&laquo;</button> <button id="next">&raquo;</button> <script src="test.js"></script>

css

* { margin: 0; padding: 0; } .slider-area { position: relative; width: 100%; height: 250px; } .boxslider { width: 100%; height: 100%; list-style: none; display: flex; /* overflow: hidden; */ /* position: relative; */ /* outline: red solid; */ } #next, #return { position: absolute; top: 125px; transform: translateY(-50%); font-size: 30px; border: none; background: rgba(0, 0, 0, 0.615); color: white; padding: 10px; } #next { right: 0; } #return { left: 0; } .hidden { display: none; } li { height: 100%; min-width: 100%; color: white; font-size: 40px; display: flex; justify-content: center; align-items: center; } li:nth-of-type(1) { background: red; } li:nth-of-type(2) { background: blue; } li:nth-of-type(3) { background: orange; } li:nth-of-type(4) { background: rebeccapurple; } li:nth-of-type(5) { background: skyblue; }

javascript

const boxslider = document.querySelector('.boxslider'); const next = document.getElementById('next'); const rtn = document.getElementById('return'); const box = boxslider.children; let Index = 0; function hid() { if (Index === 0) { rtn.classList.add('hidden'); next.classList.remove('hidden'); }; if (Index === box.length - 1) { next.classList.add('hidden'); rtn.classList.remove('hidden'); }; } hid() next.addEventListener('click', () => { Index++; hid() const boxwidth = box[0].getBoundingClientRect().width; boxslider.style.transform = `translateX(${-1 * boxwidth * Index}px)`; boxslider.style.transition = '0.4s' }); rtn.addEventListener('click', () => { Index--; hid() const boxwidth = box[0].getBoundingClientRect().width; boxslider.style.transform = `translateX(${-1 * boxwidth * Index}px)`; boxslider.style.transition = '0.4s' });

良い質問の評価を上げる

以下のような質問は評価を上げましょう

  • 質問内容が明確
  • 自分も答えを知りたい
  • 質問者以外のユーザにも役立つ

評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

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

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

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

teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

  • プログラミングに関係のない質問
  • やってほしいことだけを記載した丸投げの質問
  • 問題・課題が含まれていない質問
  • 意図的に内容が抹消された質問
  • 過去に投稿した質問と同じ内容の質問
  • 広告と受け取られるような投稿

評価を下げると、トップページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

まだ回答がついていません

会員登録して回答してみよう

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

ただいまの回答率
87.20%

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

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

質問する

関連した質問

同じタグがついた質問を見る

CSS3

CSS(Cascading Style Sheet)の第3版です。CSS3と略されることが多いです。色やデザインを柔軟に変更することが可能になります。

HTML5

HTML5 (Hyper Text Markup Language、バージョン 5)は、マークアップ言語であるHTMLの第5版です。

JavaScript

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