自动播放YouTube LazyLoad在桌面上嵌入视频?

时间:2017-11-10 16:58:03

标签: javascript jquery youtube youtube-data-api

我在一个页面上有很多YouTube LazyLoad视频,我想在桌面上访问该网站时自动启动其中一个视频加载,但是当我在手机上访问该网站时,我希望保持延迟加载图像不会慢在移动访问者的网站上,因为YouTube iframe必须下载一些文件,这些文件会降低网站的速度以显示视频。我已经有了一个可以在这里准备好LazyLoad的脚本http://jsfiddle.net/the_nexi/5qzaq59n/10/但是我无法弄清楚如何添加让我们在javascript中向脚本说一个数据类型以在页面上自动加载一个视频加载到桌面上,其他YouTube Lazyload视频应该保持懒惰状态,直到您点击它们并在手机上我想让所有视频保持懒惰甚至是应该在桌面上加载页面时自动启动的视频。为了不降低网站速度,因为普通的youtube iframe真的会减慢手机网站的速度,希望有人可以帮助我。

我已从此帖https://webdesign.tutsplus.com/tutorials/how-to-lazy-load-embedded-youtube-videos--cms-26743

获得原始代码

提前致谢。

NEXI



( function() {

	var youtube = document.querySelectorAll( ".youtube" );
	
	for (var i = 0; i < youtube.length; i++) {
		
		var source = "https://img.youtube.com/vi/"+ youtube[i].dataset.embed +"/sddefault.jpg";
		
		var image = new Image();
				image.src = source;
				image.addEventListener( "load", function() {
					youtube[ i ].appendChild( image );
				}( i ) );
		
				youtube[i].addEventListener( "click", function() {

					var iframe = document.createElement( "iframe" );

							iframe.setAttribute( "frameborder", "0" );
							iframe.setAttribute( "allowfullscreen", "" );
							iframe.setAttribute( "src", "https://www.youtube.com/embed/"+ this.dataset.embed +"?rel=0&showinfo=0&autoplay=1" );

							this.innerHTML = "";
							this.appendChild( iframe );
				} );	
	};
	
} )();
&#13;
html {
	background-color: #f3f3f3;
  font-family: sans-serif;
}
.wrapper {
	max-width: 680px;
	margin: 60px auto;
	padding: 0 20px;
}

.youtube {
	background-color: #000;
	margin-bottom: 30px;
	position: relative;
	padding-top: 56.25%;
	overflow: hidden;
	cursor: pointer;
}
.youtube img {
	width: 100%;
	top: -16.82%;
	left: 0;
	opacity: 0.7;
}
.youtube .play-button {
	width: 90px;
	height: 60px;
	background-color: #333;
	box-shadow: 0 0 30px rgba( 0,0,0,0.6 );
	z-index: 1;
	opacity: 0.8;
	border-radius: 6px;
}
.youtube .play-button:before {
	content: "";
	border-style: solid;
	border-width: 15px 0 15px 26.0px;
	border-color: transparent transparent transparent #fff;
}
.youtube img,
.youtube .play-button {
	cursor: pointer;
}
.youtube img,
.youtube iframe,
.youtube .play-button,
.youtube .play-button:before {
	position: absolute;
}
.youtube .play-button,
.youtube .play-button:before {
	top: 50%;
	left: 50%;
	-webkit-transform: translate3d( -50%, -50%, 0 );
	        transform: translate3d( -50%, -50%, 0 );
}
.youtube iframe {
	height: 100%;
	width: 100%;
	top: 0;
	left: 0;
}
&#13;
 <div class="wrapper">
  <p>I want this video to start automatically on page load on a desktop and on a mobile phone I want it to stay as lazyload like in this demo.</p>
	<div class="youtube" data-embed="4ckxTlaDJ7E">
		<div class="play-button"></div>
	</div>
  <p>But I want the other YT Lazy Load YOUTUBE Videos to stay as Lazy Load until I click the Play Button.</p>
  	<div class="youtube" data-embed="XBtPebpfVg4">
		<div class="play-button"></div>
	</div>
</div>
&#13;
&#13;
&#13;

1 个答案:

答案 0 :(得分:1)

首先声明您的点击事件,然后当您循环浏览图像时,您可以测试第一张图像&amp; viewport width并触发click事件(如果相关),如下所示:

require

这是一个working fiddle(尝试使预览窗格比740px更宽/更窄并且点击运行,在狭窄的屏幕上视频应该作为图像延迟加载,在更宽的范围内它应该自动播放)。