@HelpMeeee

Почему не работает код на телефоне, который работает на телефоне?

Есть вот такая функция, которая при наведении активирует загрузку гиф для видео.
function myfunction(el,d) {
		  $(".active-prev").remove();
    	$(".preloders").remove();
    	if ($(this).attr("data-gif")) {
        $(this).parent().append('<img src="http://site.com/loader.gif" width="100%" height="100%" class="preloders">');
        $(this)
            .parent()
            .append('<video class="active-prev" onloadeddata="$(\'.preloders\').remove();" src="' + $(this).attr("data-gif") + '" autoplay loop muted></video>');
    }
		}

Есть функция, которая отслеживает свайп, 100% рабочая, проверял алертом)
Вызываю ту же функцию для подгрузки гифок при свайпе и ничего не работает.
Вызываю таким образом
function detectswipe(el,func) {
		  swipe_det = new Object();
		  swipe_det.sX = 0; swipe_det.sY = 0; swipe_det.eX = 0; swipe_det.eY = 0;
		  var min_x = 30;  //min x swipe for horizontal swipe
		  var max_x = 30;  //max x difference for vertical swipe
		  var min_y = 50;  //min y swipe for vertical swipe
		  var max_y = 60;  //max y difference for horizontal swipe
		  var direc = "";
		  ele = document.getElementById(el);
		  ele.addEventListener('touchstart',function(e){
		    var t = e.touches[0];
		    swipe_det.sX = t.screenX; 
		    swipe_det.sY = t.screenY;
		  },false);
		  ele.addEventListener('touchmove',function(e){
		    e.preventDefault();
		    var t = e.touches[0];
		    swipe_det.eX = t.screenX; 
		    swipe_det.eY = t.screenY;    
		  },false);
		  ele.addEventListener('touchend',function(e){
		    //horizontal detection
		    if ((((swipe_det.eX - min_x > swipe_det.sX) || (swipe_det.eX + min_x < swipe_det.sX)) && ((swipe_det.eY < swipe_det.sY + max_y) && (swipe_det.sY > swipe_det.eY - max_y) && (swipe_det.eX > 0)))) {
		      if(swipe_det.eX > swipe_det.sX) direc = "r";
		      else direc = "l";
		    }
		    //vertical detection
		    else if ((((swipe_det.eY - min_y > swipe_det.sY) || (swipe_det.eY + min_y < swipe_det.sY)) && ((swipe_det.eX < swipe_det.sX + max_x) && (swipe_det.sX > swipe_det.eX - max_x) && (swipe_det.eY > 0)))) {
		      if(swipe_det.eY > swipe_det.sY) direc = "d";
		      else direc = "u";
		    }

		    if (direc != "") {
		      if(typeof func == 'function') func(el,direc);
		    }
		    direc = "";
		    swipe_det.sX = 0; swipe_det.sY = 0; swipe_det.eX = 0; swipe_det.eY = 0;
		  },false);  
		}
		detectswipe('hover_tumb',myfunction);
		function myfunction(el,d) {
		  $(".active-prev").remove();
    	$(".preloders").remove();
    	if ($(this).attr("data-gif")) {
        $(this).parent().append('<img src="http://site.com/loader.gif" width="100%" height="100%" class="preloders">');
        $(this)
            .parent()
            .append('<video class="active-prev" onloadeddata="$(\'.preloders\').remove();" src="' + $(this).attr("data-gif") + '" autoplay loop muted></video>');
    }
		}
  • Вопрос задан
  • 101 просмотр
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
27 нояб. 2024, в 13:07
10000 руб./за проект
27 нояб. 2024, в 12:53
70000 руб./за проект
27 нояб. 2024, в 12:50
25000 руб./за проект