ホームページ >ウェブフロントエンド >jsチュートリアル >ネイティブ js スキルと jQuery_javascript スキル間の単純なタブ切り替え効果の比較
タブ ページは通常、ページの美しさを考慮し、過剰な情報によってユーザーに視覚疲労を与えないよう、スペースが限られていてコンテンツが多い状況に適しています。これには幅広い用途があります。以下では、これを簡単に実装するために 2 つの方法を使用します。
まず、ページ要素を構築します。通常、ul と ol を含むタブのクリック可能な部分を運ぶにはリストを使用します。ここではタブを水平に配置するため、タブを左側にフローティングする必要があります。ページのコンテンツは div でホストできます。さらに、共通の特性を持つ要素のスタイルと動作を均一に制御する必要があるため、次の dom 構造があります:
<div id="main"> <ul id="tabbar" class="cl"> <li class="t1">t1</li> <li class="def">t2</li> <li class="def">t3</li> <li class="def">t4</li> <li class="def">t5</li> </ul> <div id="content"> <div class="cont t1">Hi !</div> <div class="cont t2">I Like You!</div> <div class="cont t3">Hello World!</div> <div class="cont t4">How Are You?</div> <div class="cont t5">I'm fine ,and you?</div> </div> </div>
ul が左にフロートされた後、後続の要素に対するフローティングの影響をクリアするために、after 疑似クラスを通じてクリア属性が設定され、同時に、ie をトリガーするためにZoomに下位バージョンの ie が追加されます。レイアウトがあります。したがって、次のスタイルがあります:
html,body,div,ul,li{margin:0; padding:0; } .cl{zoom:1;} .cl:after{display:block; height:0; clear:both; visibility:hidden; overflow:hidden; content:'.';} ul{list-style:none;} body{padding-top:100px; background:#eee; font-family:Microsoft YaHei, Arial, Helvetica, sans-serif;} #main{margin:0 auto; width:800px;} #main #tabbar{} #main #tabbar li,#main #content .cont{text-align:center; color:#fff;} #main #tabbar li{padding:0 20px; height:35px; line-height:35px; font-size:14px; cursor:pointer; float:left;} #main #content{height:350px; overflow:hidden; position:relative;} #main #content .cont{width:100%; height:350px; line-height:350px; font-size:48px; z-index:0; position:absolute;} #main #tabbar li.def{color:#333; background:#fff;} #main #tabbar li.t1,#main #content .cont.t1{color:#fff; background:#4e6b9c;} #main #tabbar li.t2,#main #content .cont.t2{color:#fff; background:#c52946;} #main #tabbar li.t3,#main #content .cont.t3{color:#fff; background:#33a6ff;} #main #tabbar li.t4,#main #content .cont.t4{color:#fff; background:#ffab4e;} #main #tabbar li.t5,#main #content .cont.t5{color:#fff; background:#64bccc;}
html部分はほぼ同じです。
ネイティブ JS を使用して実装する場合、主にクリック イベントを各 li に個別にバインドします。クリックすると、現在のコンテンツ ページが表示され、他のコンテンツ ページが非表示になります。これにより、コンテンツの透明度が増加または減少します。完全に非表示または表示になるまでタイマーを設定します。
window.onload = function(){ var tabs = document.getElementById("tabbar").getElementsByTagName("li"); var cont = document.getElementById("content").getElementsByTagName("div"); var len = cont.length; var flag = true; var fade = function(elem, callback, type){ type || (type = "in"); var px, timer; if(type == "in") { px = 0; timer = setInterval(function(){ px += 3; if(px <= 100) { elem.style.opacity ? (elem.style.opacity = (px / 100)) : (elem.style["filter"] = "alpha(opacity=" + px + ")"); } else { clearInterval(timer); elem.style.opacity ? (elem.style.opacity = 1) : (elem.style["filter"] = "alpha(opacity=100)"); callback && callback(elem); } },10); } else { px = 100; timer = setInterval(function(){ px -= 3; if(px >= 0) { document.addEventListener ? (elem.style.opacity = (px / 100)) : (elem.style["filter"] = "alpha(opacity=" + px + ")"); } else { clearInterval(timer); elem.style.opacity ? (elem.style.opacity = 0) : (elem.style["filter"] = "alpha(opacity=0)"); callback && callback(elem); } },10); } } for(var i = 0; i < len; i++) { cont[i].style.zIndex = len - i; tabs[i].index = cont[i].index = i; tabs[i].onclick = function(){ if(flag) { flag = false; cont[this.index].style.display = "block"; fade(cont[this.index]); for(var i = 0; i < len; i++) { tabs[i].className = "def"; if(tabs[i].index != this.index) { fade ( cont[i], function(elem) { elem.style.display = "none"; elem.className = "cont t" + (elem.index + 1); flag = true; }, "out" ); } } this.className = "t" + (this.index + 1); } } } };
上記からもわかるように、ネイティブ js を使用して dom を操作するのは実際には非常に面倒であり、そうでなければ「書き込みを減らし、より多くのことを行う」jQuery は誕生しません。以下は jQuery を使用した簡単な実装です:
$(function(){ var tabs = $("#tabbar li"); var cont = $("#content .cont"); var len = cont.length; cont.each(function(inx, elem){$(elem).css("z-index", len - inx);}).andSelf().hide().andSelf().eq(1).show(); tabs.click(function(){ var inx = tabs.index(this); tabs.removeAttr("class").addClass("def").andSelf().eq(inx + 1).addClass("t" + (inx + 1)); cont.fadeOut(300).not(this).andSelf().eq(inx).fadeIn(300); }); } );
この例は比較的単純ですが、非常に実用的です。もちろん、実際の作業では通常、再利用可能なコントロールをカプセル化するための基礎としてこれを使用しませんが、基本的な考え方は同じです。 。
以上がこの記事の全内容です。皆さんに気に入っていただければ幸いです。