防止iOS两次点击事件发生?

时间:2018-08-10 14:29:42

标签: javascript jquery ios click mobile-safari

是否有一种方法可以防止出现以下单击事件的iOS移动Safari上出现双击链接问题?

var self = this;
this.$thumbnail.on('click', function(e) {
  e.preventDefault();
  src = src + '&autoplay=1';
  $innerContainer.addClass('yt-hd-thumbnail-clicked');
  self.$elem.attr({
    'src': src
  });
});

我主要是在寻找JQuery解决方案。

更新:添加了完整的代码段示例

我提供了一个片段,该片段介绍了如何必须通过iOS Safari两次点击事件才能自动播放嵌入式视频:

我已根据最近的答案对原始脚本进行了修改,但仍然无法解决双击问题。

参见下文:

(function($, window, document, undefined) {
  "use strict";

  var defaults = {
    darkenThumbnail: false
  };

  function YouTubeHDThumbnail(element, options) {
    this.elem = element;
    this.$elem = $(element);
    this.settings = $.extend({}, defaults, options);
    this._defaults = defaults;
    this._name = "youTubeHDThumbnail";
    this.init();
  }

  $.extend(YouTubeHDThumbnail.prototype, {
    init: function() {
      (this.videoId = null), (this.$thumbnail = null);

      // retrieve HD thumbnail
      var src = this.$elem.attr("src"),
        srcSplit = src.split("?"),
        srcMain = null,
        srcPure = null;

      if (srcSplit.length > 0) {
        srcMain = srcSplit[0];
        srcPure = srcMain.split("/");
        this.videoId = srcPure.pop();
        this.$thumbnail = $("<a />")
          .attr({
            href: "#"
          })
          .addClass("yt-hd-thumbnail");
        let thumb = $("<img/>", {
          src: "http://i.ytimg.com/vi/" + this.videoId + "/maxresdefault.jpg"
        });
        thumb.on("load", () => {
          const src =
            thumb[0].width < 121 ?
            "http://i.ytimg.com/vi/" + this.videoId + "/hqdefault.jpg" :
            "http://i.ytimg.com/vi/" + this.videoId + "/maxresdefault.jpg";
          this.$thumbnail.append(
            $("<img/>", {
              src
            })
          );
        });
      } else {
        console.log("The src attribute of iframe is not valid.");
        return;
      }

      // create container
      var $outerContainer = $("<div />")
        .addClass("yt-hd-thumbnail-outer-container")
        .insertAfter(this.elem)
        .css("width", this.$elem.attr("width")),
        $innerContainer = $("<div />")
        .addClass("yt-hd-thumbnail-inner-container")
        .appendTo($outerContainer);

      // insert thumbnail and iframe
      if (this.settings.darkenThumbnail) {
        this.$thumbnail.addClass("yt-hd-thumbnail-darken");
      }
      $innerContainer.append(this.$thumbnail).append(this.elem);

      // add click handler to thumbnail
      var self = this;
      this.$thumbnail.on("click touchend", function(e) {
        if (e.handled === false) return;
        e.stopPropagation();
        e.preventDefault();
        e.handled = true;
        src = src + "&autoplay=1";
        $innerContainer.addClass("yt-hd-thumbnail-clicked");
        self.$elem.attr({
          src: src
        });
      });
    }
  });

  $.fn["youTubeHDThumbnail"] = function(options) {
    return this.each(function() {
      if (!$.data(this, "plugin_" + "youTubeHDThumbnail")) {
        $.data(
          this,
          "plugin_" + "youTubeHDThumbnail",
          new YouTubeHDThumbnail(this, options)
        );
      }
    });
  };
})(jQuery, window, document);

$('iframe[src*="youtube.com"]').addClass("yt-hd-thumbnail");

$("iframe.yt-hd-thumbnail").youTubeHDThumbnail({
  darkenThumbnail: true
});
.yt-hd-thumbnail-outer-container {
  position: relative;
  height: auto;
}

.yt-hd-thumbnail-inner-container {
  position: absolute;
  padding-top: 56.25%;
  width: 100%;
  height: 0;
  top: 0;
  left: 0;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail,
.yt-hd-thumbnail-inner-container>iframe {
  display: block;
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  border-width: 0;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail {
  z-index: 2;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail img {
  max-width: 100%;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail.yt-hd-thumbnail-darken:before {
  display: block;
  position: absolute;
  content: "";
  top: 0;
  left: 0;
  right: 0;
  bottom: 0;
  background-color: #000;
  opacity: 0.15;
  -webkit-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail.yt-hd-thumbnail-darken:hover:before {
  opacity: 0;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail:after {
  display: block;
  position: absolute;
  content: "";
  -webkit-mask-image: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 70"><path d="M97.94,10.95a12.53,12.53,0,0,0-8.81-8.81C81.3,0,50,0,50,0S18.7,0,10.87,2.06A12.79,12.79,0,0,0,2.06,11C0,18.77,0,35,0,35S0,51.31,2.06,59.05a12.53,12.53,0,0,0,8.81,8.81C18.78,70,50,70,50,70s31.3,0,39.13-2.06a12.53,12.53,0,0,0,8.81-8.81C100,51.31,100,35.08,100,35.08S100.08,18.77,97.94,10.95ZM40,50V20L66,35Z"/></svg>');
  mask-image: url('data:image/svg+xml; utf8, <svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 70"><path d="M97.94,10.95a12.53,12.53,0,0,0-8.81-8.81C81.3,0,50,0,50,0S18.7,0,10.87,2.06A12.79,12.79,0,0,0,2.06,11C0,18.77,0,35,0,35S0,51.31,2.06,59.05a12.53,12.53,0,0,0,8.81,8.81C18.78,70,50,70,50,70s31.3,0,39.13-2.06a12.53,12.53,0,0,0,8.81-8.81C100,51.31,100,35.08,100,35.08S100.08,18.77,97.94,10.95ZM40,50V20L66,35Z"/></svg>');
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center center;
  mask-position: center center;
  background-repeat: no-repeat;
  background-position: center center;
  background-color: white;
  width: 75px;
  height: auto;
  top: 0;
  bottom: 0;
  left: 0;
  right: 0;
  margin: auto;
  opacity: 0.85;
  -webkit-transition: all 0.5s ease;
  -o-transition: all 0.5s ease;
  transition: all 0.5s ease;
}

.yt-hd-thumbnail-inner-container>a.yt-hd-thumbnail:hover:after {
  opacity: 0;
}

.yt-hd-thumbnail-inner-container>iframe {
  max-width: 100%;
  opacity: 0;
  -webkit-transition: opacity 0.3s ease 0.3s;
  -moz-transition: opacity 0.3s ease 0.3s;
  transition: opacity 0.3s ease 0.3s;
}

.yt-hd-thumbnail-inner-container.yt-hd-thumbnail-clicked>a.yt-hd-thumbnail {
  display: none;
}

.yt-hd-thumbnail-inner-container.yt-hd-thumbnail-clicked>iframe {
  opacity: 1;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.1/jquery.min.js"></script>

<iframe width="560" height="315" src="https://www.youtube.com/embed/WUUM27T38IE?rel=0" frameborder="0" allow="autoplay; encrypted-media" allowfullscreen></iframe>

1 个答案:

答案 0 :(得分:1)

我发现使用touchend的方法似乎可以解决问题。如果有人的修复不涉及我将其添加到我所有的单击功能中,我很想知道。

var self = this;
this.$thumbnail.on('click touchend', function(e) {
  if (e.handled === false) return;
  e.stopPropagation();
  e.preventDefault();
  e.handled = true;

  src = src + '&autoplay=1';
  $innerContainer.addClass('yt-hd-thumbnail-clicked');
  self.$elem.attr({
    'src': src
  });
});