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

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

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

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

HTML5

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

jQueryプラグイン

jQueryの拡張機能。 様々な種類があり、その数は膨大です。公開済みのプラグインの他にも、自作することもできます。 jQueryで利用できるようにしておくだけで、導入およびカスタマイズが比較的容易に行なえます。

JavaScript

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

jQuery

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

Q&A

1回答

981閲覧

jQueryによるスライドのタイミングについて

espil

総合スコア19

CSS3

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

HTML5

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

jQueryプラグイン

jQueryの拡張機能。 様々な種類があり、その数は膨大です。公開済みのプラグインの他にも、自作することもできます。 jQueryで利用できるようにしておくだけで、導入およびカスタマイズが比較的容易に行なえます。

JavaScript

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

jQuery

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

0グッド

0クリップ

投稿2020/06/16 10:25

編集2020/06/16 10:28

プログラミング始めて半年未満の初心者です。
今回jQueryの修正方法をお伺いしたく失礼致します。
以下コードを実装して頂くと一目で問題箇所が見つかると思います
【問題箇所】
homeに実装したスライドショーが以下の時、タイミングがおかしくなる。
home(正常に作動)➡link-1へ移動➡homeへ移動(スライドのタイミングがおかしくなります。。)

html(index)

1</head> 2 <body> 3 <header></header> 4 <div id="select"> 5 <ul class="menu"> 6 <li class="navigation"><a href="home/home.html">home</a></li> 7 <li class="navigation"><a href="link-1/link-1.html">link-1</a></li> 8 </ul> 9</div> 10 <main id="contents"> 11 <div class="pageDisplay"> 12 </div> 13 </main> 14 <nav> 15 </nav> 16 <aside id="right"><a href="">Blog</a></aside> 17 <aside id="banner"> 18 </aside> 19 <footer> 20 </footer> 21</body> 22```CSS(index)

@charset "utf-8";
@import url("home.css");
body {
display: grid;
margin: 0;
height:100%;
min-height: 100vh;
grid-template-rows: 130px 50px 800px 150px 200px;
grid-template-columns: 15% 70% 15%;
grid-template-areas:
"title title title"
"menu1 menu1 menu1 "
"left main right "
"banner banner banner"
"footer footer footer";
}
header{
grid-area: title;
}
#select{
grid-area: menu1;

}
main {
grid-area:main;
}
nav {
grid-area: left;
background-color:#E1DDDD;
}
#right {
grid-area: right;
background-color:#E1DDDD;
}
#banner{
grid-area: banner;
background: #111111;
}
#banner img{
padding-left:5%
}
footer {
grid-area: footer;
background: #000000;
}

#select {
font-family: 'Open Sans', sans-serif;
background-color:#3a3b3b;
text-align: center;
position:fixed;
top:130px;
left:0px;
width: 100%;
}
.menu {
position: relative;
list-style: none;
font-weight: 400;
font-size: 0;
text-transform: uppercase;
display: inline-block;
padding: 0;

}
.menu li {
font-size: 0.8rem;
display: inline-block;
position: relative;
padding: 15px 20px;
cursor: pointer;
z-index: 5;
min-width: 120px;
}
header {
height:130px;
width: 100%;
background-color:#FFFFFF;
background-size: 100%;
position:fixed;
top:0%;
left: 0%;
}

js(index)

$(function(){
//ページを表示させる箇所の設定
var $content = $('.pageDisplay');
//ボタンをクリックした時の処理
$(document).on('click', '.menu a',function(event) {
event.preventDefault();
//.menu aのhrefにあるリンク先を保存
var link = $(this).attr("href");
//リンク先が今と同じであれば遷移しない
if(link == lastpage){
return false;
}else{
$content.fadeOut(600, function() {
getPage(link);
});
//今のリンク先を保存
lastpage = link;
}

}); //初期設定 getPage("home/home.html"); var lastpage = "home/home.html"; //ページを取得してくる

function getPage(elm){
$.ajax({
type: 'GET',
url: elm,
dataType: 'html',
}).done(function (data) {
$content.html(data).fadeIn(600);
}).fail(function (data){
alert('問題がありました。');
});
}
});

```html.js(home)
<script src="../js/jquery-3.4.1.js" type="text/javascript"></script> <script> jQuery(document).ready(function ($) { startSlider($('#slider'), 30); // Slide container ID, SlideShow interval function startSlider(obj, timer) { var obj, timer; var id = "#"+obj.attr("id"); var slideCount = obj.find('ul li').length; slideWidth = obj.attr("data-width"); var sliderUlWidth = (slideCount+1) * slideWidth; var time = 2; var $bar, isPause, tick, percentTime; isPause = false; //false for auto slideshow $bar = obj.find('.progress .bar'); function startProgressbar() { resetProgressbar(); percentTime = 0; tick = setInterval(interval, timer); }       function interval() { if (isPause === false) { percentTime += 1 / (time + 0.1); $bar.css({ width: percentTime + "%" }); if (percentTime >= 100) { moveRight(); startProgressbar(); } } } function resetProgressbar() { $bar.css({ width: 0 + '%' }); clearTimeout(tick); }      function startslide() { $(id+' ul li:last-child').prependTo(id+' ul'); obj.find('ul').css({ width: sliderUlWidth+'vw', marginLeft: - slideWidth+'vw' }); obj.find('ul li:last-child').appendTo(obj.attr('id')+' ul'); } if (slideCount>1) { startslide(); startProgressbar(); } else { $(id+' button.control_prev').hide(); $(id+' button.control_next').hide(); } function moveLeft() { $(id+' ul').css( { transition: "1s", transform: "translateX(" + slideWidth + "vw)" }); setTimeout( function() { $(id+' ul li:last-child').prependTo(id+' ul'); $(id+' ul').css( { transition: "none", transform: "translateX(" + 0 + "vw)" }); $('li.actslide').prev().addClass('actslide').next().removeClass('actslide'); }, 1000 ); } function moveRight2() { // 2つのスライドのみを修正 あやしい $(id+' ul li:first-child').appendTo(id+' ul'); $(id+' ul').css( { transition: "none", transform: "translateX(100vw)"}).delay(); setTimeout( function() { $(id+' ul').css( { transition: "1s", transform: "translateX(0vw)" }); }, 100, setTimeout( function() { $(id+' ul').css( { transition: "none", transform: "translateX(0vw)" }); $('li.actslide').next().addClass('actslide').prev().removeClass('actslide'); }, 1000 ) ); } function moveRight() { if (slideCount>2) { $(id+' ul').css( { transition: "1s", transform: "translateX(" + (-1)*slideWidth + "vw)" }); setTimeout( function() { $(id+' ul li:first-child').appendTo(id+' ul'); $(id+' ul').css( { transition: "none", transform: "translateX(" + 0 + "vw)" }); $('li.actslide').next().addClass('actslide').prev().removeClass('actslide'); }, 1000 ); } else { moveRight2(); } } $(id+' button.control_prev').click(function () { moveLeft(); startProgressbar(); }); $(id+' button.control_next').click(function () { moveRight(); startProgressbar(); }); $(id+' .progress').click(function() { if (isPause === false) { isPause = true; } else { isPause = false; } }); }; }); </script> </head> <body> <div class="slider" id="slider" data-width="100"> <button class="control_next">&rarr;</button> <button class="control_prev">&larr;</button> <ul class="slideimg"> <li class="actslide"> <div class="slide" style="background: #90cc82" > </div> </li> <li> <div class="slide" style="background: #02517a" > </div> </li> <li> <div class="slide" style="background: #c4af03" > </div> </li> </ul> <div class="progress"> <div class="bar"></div> </div> </div> </body> ``` ```css .slider { position: relative; }

#slider {
position: relative;
overflow: hidden;
width: 100% !important;
}
#slider ul {
position: relative;
margin: 0;
padding: 0;
height: 600px;
width: 99999px;
overflow: hidden;
list-style: none;
z-index: -2
}
#slider ul li {
position: relative;
display: block;
float: left;
margin: 0;
padding: 0;
width: 100vw;
height: 600px;
text-align: center;
}
#slider ul li .slide {
background-size: cover;
height: 100vh;
}

button.control_prev, button.control_next {
position: absolute;
top: 50%;
z-index: -1;
display: block;
border: none;
width: 2em;
height: 2em;
line-height: 1.9em;
background: rgba(255, 255, 255, 0.3);
color: #fff;
text-align: center;
text-decoration: none;
font-weight: 600;
font-size: 2rem;
opacity: 0.8;
cursor: pointer;
border-radius: 50%;
transform: translateY(-50%);
}
button.control_prev:focus, button.control_next:focus {
outline: none;
border: 1px rgba(255, 255, 255, 0.5) solid;
}
button.control_prev:hover, button.control_next:hover {
opacity: 1;
-webkit-transition: all 0.2s ease;
}

button.control_prev {
left: 2rem;
}

button.control_next {
right: 2rem;
}

.progress {
position: absolute;
background: rgba(255, 255, 255, 0.3);
height: .5rem;
width: 100%;
bottom: 0;
border-top: 1px rgba(0, 0, 0, 0.15) solid;
}
.progress .bar {
height: 100%;
width: 0%;
background: #fff;
}

html(link

<body> <h1>link先です</h1> </body> ```

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

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

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

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

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

m.ts10806

2020/06/16 12:38

>以下コードを実装して頂くと一目で問題箇所が見つかると思います。 意図不明のコメントです。 見つかるのが分かっているのでしたら自身で問題把握できているということでは? 何が問題で、どこでどう詰まっているのでしょうか。
m.ts10806

2020/06/16 12:39

コードのインデントのほうが目について、コードを読む気にならないですし。(当然動かしてみようとも思えません)
espil

2020/06/16 13:58 編集

編集します
guest

回答1

0

別の方法でやります。解決済。

投稿2020/06/16 19:46

espil

総合スコア19

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

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

m.ts10806

2020/06/16 20:58

質問はまだ「受付中」になっていますし、何の解決にもなっていません。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

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

アカウントをお持ちの方は

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問