前提・実現したいこと
JavaScriptでスマホでスライドをした時に画像が切り替わるようにしたいのですが、iOS10以降は無事動くのですが、9以前では動いてくれません。どこが問題なのかもわからないので、場所の指摘、よろしければ改善方法なども教えてください。
発生している問題・エラーメッセージ
iOS9の端末では動作がしません。
該当のソースコード
JavaScript
1function setSwipe(elem) { 2 let t = document.querySelector(elem); 3 let startX; // タッチ開始 x座標 4 let startY; // タッチ開始 y座標 5 let moveX; // スワイプ中の x座標 6 let moveY; // スワイプ中の y座標 7 let dist = 30; 8 9 t.addEventListener("touchstart", function(e) { 10 e.preventDefault(); 11 startX = e.touches[0].pageX; 12 startY = e.touches[0].pageY; 13 }); 14 15 t.addEventListener("touchmove", function(e) { 16 e.preventDefault(); 17 moveX = e.changedTouches[0].pageX; 18 moveY = e.changedTouches[0].pageY; 19 }); 20 21 t.addEventListener("touchend", function(e) { 22 if (startX > moveX && startX > moveX + dist) { // unからupにスワイプ 23 var img = document.getElementById('ill'); 24 var src = img.getAttribute('src'); 25 var num = Number(img.className); 26 var chang= ( '000' + (num+1) ).slice( -3 ); 27 var change= chang+".jpg"; 28 ill.setAttribute('src', change); 29 ill.setAttribute('class', chang); 30 } 31 else if (startX < moveX && startX + dist < moveX) { // upからunにスワイプ 32 var img = document.getElementById('ill'); 33 var src = img.getAttribute('src'); 34 var num = Number(img.className); 35 if((num-1)>0){ 36 var chang= ( '000' + (num-1) ).slice( -3 ); 37 var change= chang+".jpg"; 38 ill.setAttribute('src', change); 39 ill.setAttribute('class', chang); 40 } 41 } 42 }); 43}; 44 window.addEventListener("load", function(){ 45 setSwipe("#ill"); 46 });
試したこと
<img id="ill" class="001" src="001.jpg"> この画像をスライドすると <img id="ill" class="002" src="002.jpg"> こう切り替え、表示する画像を2枚目にしたい。補足情報(FW/ツールのバージョンなど)
回答2件
あなたの回答
tips
プレビュー