ホーム » ブログ » 要素を可視範囲に到達したら非同期的にコンテンツを表示方法
このエントリーをはてなブックマークに追加
@2018/08/22

スポンサーリンク
画面スクロールである要素を画面可視範囲に入ったら、コンテンツを動的に表示する方法です。
ローカルで確認済み、コピペーで使えるので、ぜひご利用ください。
ちなみに、オンラインデモを近いうちにアップロードする予定です。
また、筆者運営している別のサイトbenri.jpにも適用したいと考えており、ぜひご覧ください。

以下ソースコードです。




<!DOCTYPE html>
<html lang='ja'>
<head>
<meta charset='utf-8'>
<style>
html {
  height: 200%;
  min-height: 400px;
  text-align: center;
  font-family: sans-serif;
  padding-top: 3.5em;
}

/*-------------------------------------- Processingアニメーション--- */
.Processing-wrap {
	width: 100%;
	display: table;
	position: relative;
	/*border: 1px solid #CCC;*/
	height: 100%;
}
.Processing {
	width: 100%;
	height: 100%;
	margin: 0 auto;
	text-align: center;
	display: table-cell;
	vertical-align: middle;
}
.Processing__bounce {
	width: 12px;
	height: 12px;
	background-color: rgba(0,0,255,1);
	border-radius: 100%;
	display: inline-block;
	-webkit-animation: Processing__bouncedelay 1.4s infinite ease-in-out;
	animation: Processing__bouncedelay 1.4s infinite ease-in-out;
	-webkit-animation-fill-mode: both;
	animation-fill-mode: both;
	display: inline-block;
	box-sizing: border-box;

}
.Processing__bounce1 {
    -webkit-animation-delay: -.64s;
    animation-delay: -.64s;
    opacity: 0.6;
}
.Processing__bounce2 {
    -webkit-animation-delay: -.48s;
    animation-delay: -.48s;
    opacity: 0.7;
}
.Processing__bounce3 {
    -webkit-animation-delay: -.32s;
    animation-delay: -.32s;
    opacity: 0.8;
}
.Processing__bounce4 {
    -webkit-animation-delay: -.16s;
    animation-delay: -.16s;
    opacity: 0.9;
}

@-webkit-keyframes Processing__bouncedelay {
	0%,100%,80% {-webkit-transform: scale(0)}
	40% {-webkit-transform: scale(1)}
}
@keyframes Processing__bouncedelay {
	0%,100%,80% {transform: scale(0);-webkit-transform: scale(0)}
	40% {transform: scale(1);-webkit-transform: scale(1)}
}

/*-------------------------------------- target定義--- */
#target,
#target2,
#target3,
#target4,
#target5 {
  display: inline-block;
  margin: 0 auto 50vh;
  padding: 14em 3em;
  position: relative;
}
.UnderInquiry {
	 /* background-color: #DEDEDE;*/
}
.FinishedInquiry {
	background-color: transparent;
	color: #222;
}

</style>
</head>
<body>

	<p>下へスクロールしたら、非同期でコンテンツを取得にし表示します….<p>

	<br>
	<div id="target" class="">Target</div>

	<br>--------------------------Target2--------------------------<br>
	<div id="target2"class="">Targe2t</div>

	<br>--------------------------Target3--------------------------<br>
	<div id="target3"class="">Target3</div>

	<br>--------------------------Target4--------------------------<br>
	<div id="target4"class="">Target4</div>

	<br>--------------------------Target5--------------------------<br>
	<div id="target5"class="">Target5</div>

	<script >
	/*************************************************************
	 * observerCallback receives 
	 * a list of IntersectionObserverEntry objects and the observer
	 *************************************************************/
	function observerCallback(entries, observer) {

	  for (entry of entries) {
	    //console.log(entry);
	    //監視対象の表示割合
	    let ratio = entry.intersectionRatio;

		if (ratio >= 1) {
			console.log('INFO:' + entry.target.id + 'が完全視界に入りました。');
			dummyFun(entry.target.id);
	    } else if (ratio <= 0) {
	    	console.log('INFO:' + entry.target.id + 'が視界から去りました。');
	    } else {// entering OR leaving
	    	console.log('INFO:' + entry.target.id + 'の一部が視界に入っています。');
	    	dummyFun(entry.target.id);
	    }
	  }
	  
	}

	/* This custom threshold invokes the handler(observerCallback) whenever:
	     1. The target begins entering the viewport (0 < ratio < 1).
	     2. The target fully enters the viewport (ratio >= 1).
	     3. The target begins leaving the viewport (1 > ratio > 0).
	     4. The target fully leaves the viewport (ratio <= 0).
	     Try adding additional thresholds! 
	*/ 

	let observerOptions = {//オプション
		root: null,
		rootMargin: '0px',
		threshold: [0,1]
	}

	let observer = new IntersectionObserver(observerCallback, observerOptions);

	//監視する要素を配列に入れる
	var targetList = new Array('target','target2','target3','target4','target5');

	//要素を監視
	for(var i in targetList) {
		var targetId = targetList[i];
		observer.observe(document.getElementById(targetId));
	}

	/*
	 * ダミーメソッドです。
	 * 実業務の場合、非同期でサーバから取得した内容を、引数でID指定した要素にセットして表示。
	 */
	function dummyFun (elemId) {
		var emObj = document.getElementById(elemId);
		//初期状態の場合、処理
		if(emObj.className == ''){
		    emObj.className = 'UnderInquiry';
		    // 処理中に画面で表示
		    emObj.innerHTML  = document.getElementById('temp-proccessing').innerHTML ;
		    
		    //TODO get date from server
	    	setTimeout(function(){
				emObj = document.getElementById(elemId);
				emObj.className = 'FinishedInquiry';
				var dummyMsg = 'welcome to ' + elemId + '<br>';
				dummyMsg += '最新の内容を取得しました。';
				emObj.innerHTML = dummyMsg;
			}, 3000);
	    }
	    
	    return;
	}
	</script>
	<!-- 処理中のアニメーション(入れ子として用意しておく) -->
	<div id="temp-proccessing" style="display:none;">
		<div class="Processing-wrap">
			<div class="Processing">
				<div class="Processing__bounce Processing__bounce1"></div>
				<div class="Processing__bounce Processing__bounce2"></div>
				<div class="Processing__bounce Processing__bounce3"></div>
				<div class="Processing__bounce Processing__bounce4"></div>
				<div class="Processing__bounce Processing__bounce5"></div>
			</div>
		</div>
	</div>

</body>
</html>

♪ 当記事がお役に立ちましたらシェアして頂ければ嬉しいです。
0人
このエントリーをはてなブックマークに追加


★ 当記事を閲覧の方は下記の【関連記事】も閲覧していました。

お名前:

 

EMAIL:

 

URL:

 

認証コード:

zanmai.net-safecode

 


※会員の方は認証コードを要らないから、新規登録をオススメ!

check