カルーセル画像は、現在、Web サイトのページで最も一般的なエフェクトの 1 つで、淘宝網、JD.com などの多くの Web サイトで使用されています。いくつかの自動タブも必要ですが、再現性が高くなります。ここで共有し、js ネイティブ コードを使用してカルーセル画像の一般的な効果を実現してください。
同じサイズの一連の画像がタイル状に並べられ、CSS レイアウトを使用して 1 つの画像のみを表示し、残りの画像を非表示にします。タイマーを使用してオフセットを計算して自動再生を実現します。
まず、親コンテナのバナーにはすべてのコンテンツが格納され、子コンテナの img-list には画像が格納されます。サブコンテナリストにはボタンドットが格納されます。ドットの背景画像を使用しました!
<p id="banner"> <ul id="img-list"> <li><img src="images/banner1.png" alt="1"/></li> <li><img src="images/banner2.jpg" alt="2"/></li> <li><img src="images/banner3.png" alt="3"/></li> </ul> <p id="list"> <span index="1" class="on"></span> <span index="2"></span> <span index="3"></span> </p> </p>
1. ボックス モデル、ドキュメント フロー、および絶対配置の問題を理解します。
2. 画像の幅と高さは固定です。まず、img-list で 3 つの画像の合計幅を設定し、overflow: hidden;! で余分な部分を隠します。右の画像の下にある li 設定をロードしてフローティングします。
3. リストスパンの幅と高さを修正し、背景画像を与えます。最初の画像にデフォルトの黄色のドット画像を設定します。
#banner { width:100%; padding:0; clear: both; position: relative; height: 400px; z-index:1; } #img-list { display: block; width:5760px; height: 400px; overflow: hidden; z-index:1; position: relative; } #img-list li{ float: left; width:100%; height: 400px; overflow: hidden; /* position: absolute; top:0; left:0; */ z-index: 2; } #list { width:100%; height:18px; text-align: center; position: absolute; bottom: 10px; z-index: 100; } #list > span { width:18px; height: 18px; overflow: hidden; display: inline-block; margin:0 2px; background: url(../images/yuan.png); cursor: pointer; } #list .on { background: url(../images/huanyu.png); }
1. まず、自動再生機能を設定します
2. 次に、マウスがコンテナ上をスライドすると再生が停止し、マウスがコンテナ全体から離れると次の画像まで再生を続けます。
3. 自動再生関数を定義して呼び出します
var banner=document.getElementById('banner'); var imglist=document.getElementById('img-list').getElementsByTagName("li"); var list=document.getElementById('list').getElementsByTagName('span'); var index=0; var timer=null; //设置自动播放函数 function autoPlay () { if (++index >= imglist.length) {index = 0}; changeImg(index); } // 鼠标划过整个容器时停止自动播放 banner.onmouseover = function () { clearInterval(timer); } // 鼠标离开整个容器时继续播放至下一张 banner.onmouseout=function(){ timer=setInterval(autoPlay,2000); } / 定义并调用自动播放函数 timer = setInterval(autoPlay, 2000);
次に、画像の切り替え関数を定義します
// 定义图片切换函数 function changeImg (curIndex) { for (var i = 0; i < imglist.length; i++) { imglist[i].style.display = "none"; list[i].className = ""; } imglist[curIndex].style.display = "block"; list[curIndex].className = "on"; }
最後に、すべてのデジタルナビゲーションを走査して、対応する画像へのスワイプ切り替えを実現し、そのインデックス値を取得する必要があります
for (var i = 0; i < list.length; i++) { list[i].index=i; list[i].onmouseover = function () { clearInterval(timer); changeImg(this.index); };
カルーセルのコードはすべて完成しました。
関連する推奨事項:
jquery は PC 側のカルーセル チャート コードを実装します
以上がネイティブjsは自動カルーセルチャートを実装しますの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。