이 문서의 예에서는 jquery 동적 탐색 플러그인인 DynamicNav의 사용법을 설명합니다. 참고할 수 있도록 모든 사람과 공유하세요. 세부 내용은 다음과 같습니다.
자체 작성된 jquery 동적 탐색 플러그인인 DynamicNav는 다음과 같습니다.
먼저 모든 li에 span 태그를 삽입하고 li에 a 태그를 포함시킵니다
둘째, a 태그의 복사본을 복사하여 범위에 삽입합니다. 이제 범위에 두 개의 a 태그가 있습니다.
셋째, 전달된 매개변수에 따라 세로로 전환할지 가로로 전환할지 결정합니다. 세로인 경우에는 스팬의 너비를 태그의 너비로 변경합니다. 이때 두 개의 a 태그가 세로로 배열되어야 합니다. lioverflow:hidden을 변경하세요. 그렇지 않으면 2개의 a 태그가 표시됩니다. 가로인 경우 스팬 너비를 a 태그 2개 너비로 변경하고, li 너비를 태그 너비 1개로 변경합니다. CSS에서 li 너비를 설정하지 않았기 때문에 너비에 따라 달라집니다. a 태그를 변경하려면 모든 탐색 메뉴를 동일한 너비로 만들려면 CSS의 li에 너비 속성을 추가하면 됩니다.
네 번째 단계는 마우스가 지나가고 떠날 때 효과를 처리하기 위해 호버 이벤트를 사용하여 애니메이션 효과 만들기를 시작하는 것입니다.
jquery의 animate를 사용하여 범위의 margin-top(세로 방향)과 margin-left(가로 방향)를 변경하세요.
런닝 효과 스크린샷은 다음과 같습니다.
온라인 데모 주소는 다음과 같습니다.
http://demo.jb51.net/js/2015/jquery-tab-cha-plug-dynamicNav-codes/
구체적인 코드는 다음과 같습니다.
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>动态导航插件</title> <style type="text/css"> <!-- body, td, th { font-size: 14px; background-color:#FFF } h1{border-bottom:1px solid #999; margin:50px 60px;} /*导航默认样式,可根据实际情况修改*/ * { margin:0; padding:0 } .nav { width:980px; height:30px; left:50%; margin-left:-490px; list-style:none; position:relative; } .nav li { display:inline-block; margin:0 3px; position:relative; overflow:hidden; height:30px; /*建议此高度大于等于里面的a标签高度*/ float:left; } .nav li span { display:inline-block; overflow:hidden } .nav li a { text-decoration:none; outline:none; color:#666; display:inline-block; padding:0 10px; text-align:center; background-color: #E1E1E1; font-weight:bold; height:30px; line-height:30px; } /*鼠标经过时样式*/ .nav li a.over { background-color:#666; color:#FFF } --> </style> <script type=text/javascript src="jquery-1.6.2.min.js"></script> <script type="text/javascript"> (function($){ $.fn.dynamicNav=function(options){ //默认配置 var defaults = { direction:"up", //动画切换方向,总共4种up 、down 、left 、right duration:100 //三种预定速度之一的字符串("slow", "normal", or "fast")或表示动画时长的毫秒数值(如:1000) }; // 覆盖默认配置 var opts = $.extend(defaults, options); this.each(function(){ var navList=$(this).find("li"), navLink=navList.find("a"); //在a标签外侧插入span navList.wrapInner("<span></span>"); var span=navLink.parent(); //判断是否垂直切换 if(opts.direction=="up" || opts.direction=="down"){ var v=true; } //判断是否改变span初始位置及a样式 if(opts.direction=="right" || opts.direction=="down"){ var restSpan=true; } navLink.each(function(){ //获取a高度和宽度 var w=$(this).outerWidth(), p=$(this).parent(); //初始复制现有a标签 $(this).clone().appendTo(p).addClass("over"); //如果是垂直切换 if(v){ p.css("width",w); }else{ p.css("width",2*w).parent().css("width",w); } }); //如果向右或向下切换,改变span初始位置及a样式 if(restSpan){ span.each(function(){ if(opts.direction=="right"){ $(this).css({"margin-left":-$(this).outerWidth()/2}); } if(opts.direction=="down"){ $(this).css({"margin-top" : -$(this).outerHeight()/2}); } $(this) .find('a') .last() .removeClass("over") .prev() .addClass("over"); }); } //鼠标经过时动画函数 function over(o){ o.animate(v?{"margin-top": -o.outerHeight()/2}:{"margin-left": -o.outerWidth()/2}, opts.duration); } //鼠标移开时动画函数 function out(o){ o.animate(v?{"margin-top":0}:{"margin-left": 0}, opts.duration); } //鼠标经过和离开 span.hover(function(){ restSpan ? out($(this)) : over($(this)); },function(){ restSpan ? over($(this)) : out($(this)); }); }); }; })(jQuery); $(function(){ //向左 $("#nav1").dynamicNav({ direction:"left", //动画切换方向,总共4种up 、down 、left 、right duration:300 //三种预定速度之一的字符串("slow", "normal", or "fast")或表示动画时长的毫秒数值(如:1000) }); //向右 $("#nav2").dynamicNav({ direction:"right", duration:200 }); //向上 $("#nav3").dynamicNav({ direction:"up", duration:100 }); //向下 $("#nav4").dynamicNav({ direction:"down", duration:400 }); }); </script> </head> <body> <h1>向左(速度300毫秒)</h1> <ul class="nav" id="nav1"> <li><a href="#">首页</a></li> <li><a href="#">前端技术</a></li> <li><a href="#">视觉设计</a></li> <li><a href="#">文章归档</a></li> <li><a href="#">工具/书籍</a></li> <li><a href="#">关于我</a></li> </ul> <h1>向右(速度200毫秒)</h1> <ul class="nav" id="nav2"> <li><a href="#">首页</a></li> <li><a href="#">前端技术</a></li> <li><a href="#">视觉设计</a></li> <li><a href="#">文章归档</a></li> <li><a href="#">工具/书籍</a></li> <li><a href="#">关于我</a></li> </ul> <h1>向上(速度100毫秒)</h1> <ul class="nav" id="nav3"> <li><a href="#">首页</a></li> <li><a href="#">前端技术</a></li> <li><a href="#">视觉设计</a></li> <li><a href="#">文章归档</a></li> <li><a href="#">工具/书籍</a></li> <li><a href="#">关于我</a></li> </ul> <h1>向下(速度400毫秒)</h1> <ul class="nav" id="nav4"> <li><a href="#">首页</a></li> <li><a href="#">前端技术</a></li> <li><a href="#">视觉设计</a></li> <li><a href="#">文章归档</a></li> <li><a href="#">工具/书籍</a></li> <li><a href="#">关于我</a></li> </ul> </body> </html>
이 기사가 모든 사람의 jquery 프로그래밍 설계에 도움이 되기를 바랍니다.