同一页面可多次调用jquery折叠菜单

//原生js版本 ***** start
window.onload=function(){
//共用函数区
var ibase={
//document.getelementbyid
id: function(name){return document.getelementbyid(name)},
//通过class获取元素
getbyclass: function(name,tagname,elem){
var c=[];
var re=new regexp('(^|s)'+name+'(|s$)');
var e=(elem || document).getelementsbytagname(tagname || '*');
for(var i=0; i < e.length; i++){
if(re.test(e[i].classname)){
c.push(e[i]);
}
}
return c;
},
//获取样式属性
attrstyle: function(elem,attr){
if(elem.attr){
return elem.style[attr];
}else if(elem.currentstyle){
return elem.currentstyle[attr];
}else if(document.defaultview && document.defaultview.getcomputedstyle){
attr=attr.replace(/([a-z])/g,'-$1').tolowercase();
return document.defaultview.getcomputedstyle(elem,null).getpropertyvalue(attr);
}else{
return null;
}
},
//获取祖辈元素中符合指定样式的元素
parents: function(elem,name){
var r=new regexp('(^|s)'+name+'(|s$)');
elem=elem.parentnode;
if(elem!=null){
return r.test(elem.classname) ? elem : ibase.parent(elem,name) || null;
}
},
//取索引值
index: function(cur,obj){
for(var i=0; i < obj.length; i++){
if(obj[i]==cur){
return i;
}
}
}

}

//变量定义
var listbox=ibase.getbyclass('js','div');
var navitem=ibase.id('demo').getelementsbytagname('h2');//此处将jq区块中的h2也取到了,所以页面会有个小小的错误
var icoitem=null,boxitem=null,boxdisplay=null,elemindex=null,elemparent=null;
//初始化展开第一个
for(var i=0; i < listbox.length;i++){
ibase.getbyclass('box','div',listbox[i])[0].style.display='block';
listbox[i].getelementsbytagname('span')[0].innerhtml='-';
}
//遍历所有点击项
for(var i=0; i < navitem.length;i++){
navitem[i].onclick=function(){
elemparent=ibase.parents(this,'js');//获取当前点击所在区块
navitem=elemparent.getelementsbytagname('h2');//获取当前区块下的点击项
icoitem=elemparent.getelementsbytagname('span');//获取当前区块下的展开关闭
boxitem=ibase.getbyclass('box','div',elemparent);//获取需要控制的区块
elemindex=ibase.index(this,navitem);//获取当前点击在当前区块点击项中的索引
//切换展开关闭图标
icoitem[elemindex].innerhtml= icoitem[elemindex].innerhtml=='-' ? '+' : '-';
if(ibase.attrstyle(boxitem[elemindex],'display')=='block'){
//控制项展开状态下,隐藏当前,展开其他的第一项
//此处有个展开0/1的判断,因为当点击第一个时是不能再展开第一个的
boxitem[elemindex].style.display='none';
if(elemindex==0){
boxitem[1].style.display='block';
icoitem[1].innerhtml='-'
}else{
boxitem[0].style.display='block'
icoitem[0].innerhtml='-'
}
}else{
//控制项展开状态下,展开当前,隐藏其他项
boxitem[elemindex].style.display='block';
for(var k=0;k < boxitem.length; k++){
if(k!=elemindex){
boxitem[k].style.display='none';
icoitem[k].innerhtml='+';
}
}
}
}
}

}

//jquery版本 ***** start
$(function(){
//变量定义区
var _listbox=$('.jq');
var _navitem=$('.jq>h2');
var _boxitem=null, _icoitem=null, _parents=null, _index=null;

//初始化第一个展开
_listbox.each(function(i){
$(this).find('div.box').eq(0).show();
$(this).find('h2>span').eq(0).text('-');
});

//遍历所有的点击项
_navitem.each(function(i){
$(this).click(function(){
//找到当前点击父元素为listbox(单个区块)的元素
_parents=$(this).parents('.listbox');
_navitem=_parents.find('h2');//此区块中的点击项
_icoitem=_parents.find('span');//此区块中的展开关闭图标
_boxitem=_parents.find('div.box');//此区块中展开关闭项
_index=_navitem.index(this);//取得当前点击在当前区块下点击项中的索引值
if(_boxitem.eq(_index).is(':visible')){
//若当前点击项下的展开关闭项是显示的,则关闭,同时展开另外项中的第一个
_boxitem.eq(_index).hide().end().not(':eq('+_index+')').first().show();
_icoitem.eq(_index).text('+').end().not(':eq('+_index+')').first().text('-');
}else{
//若当前点击项下的展开关闭项是隐藏的,则展开,同时隐藏其他项
_boxitem.eq(_index).show().end().not(':eq('+_index+')').hide();
_icoitem.eq(_index).text('-').end().not(':eq('+_index+')').text('+');
}
});
});
});

时间: 2024-08-31 15:28:37

同一页面可多次调用jquery折叠菜单的相关文章

jquery 折叠菜单代码

;(function($) { function load(settings, root, child, container) {  $.getJSON(settings.url, {root: root}, function(response) {   function createNode(parent) {    var current = $("<li/>").attr("id", this.id || "").html(&q

jquery 折叠菜单效果代码

  html代码 <script language="网页特效" type="text/javascript"> $(document).ready(function () { //将二级菜单设置为不可见 $(".faqlist").css教程("display", "none"); //单击一级菜单触发的事件 $(".bartitlefaq").click(function

jQuery实现的简单折叠菜单(折叠面板)效果代码_jquery

本文实例讲述了jQuery实现的简单折叠菜单(折叠面板)效果代码.分享给大家供大家参考.具体如下: 这是一款基于jQuery实现的折叠菜单,可展开一些内容,实际上称它为一个面板比较好,是一个折叠面板,使用了jQuery1.6.2插件. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-simple-toggle-zd-menu-codes/ 具体代码如下: <!DOCTYPE html PUBLIC "-//W3C//DTD X

收藏三款jquery实现折叠菜单代码

<html> <head> <title>伸缩的菜单,用jquery重写</title> <style> <!-- body{  background-color:#ffdee0; } #navigation {  width:200px;  font-family:arial; } #navigation > ul {  list-style-type:none;    /* 不显示项目符号 */  margin:0px;  pad

基于jQuery实现简单的折叠菜单效果_jquery

本文实例讲述了JQuery实现简单的折叠菜单效果代码.分享给大家供大家参考.具体如下: 运行效果截图如下: Html代码如下: <div class="box"> <p>菜单一</p> <ul> <li><a>1111</a></li> <li><a>1111</a></li> <li><a>1111</a>

jQuery实现的折叠菜单效果代码

这是一款jQuery采用连缀写法实现的折叠菜单效果:     代码如下: <!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&g

jQuery实现有动画淡出效果的二级折叠菜单代码_jquery

本文实例讲述了jQuery实现有动画淡出效果的二级折叠菜单代码.分享给大家供大家参考,具体如下: 这里介绍jQuery实现有动画淡出效果的二级折叠菜单代码,相当不错,因考虑功能的实现,所以没有怎么美化,不过这样也好,可以给大家更多的空间来修饰美化,想怎么弄就怎么弄了. 运行效果截图如下: 在线演示地址如下: http://demo.jb51.net/js/2015/jquery-dh-flash-fade-in-out-2-menu-demo/ 具体代码如下: <!DOCTYPE html PU

javascript 滑动式折叠菜单实现代码

先看看效果, 这很像后台的操作吧,好了下面我们来看实例方法 js代码如下  代码如下 复制代码 <script type="text/javascript"> function SDMenu(id) {     if (!document.getElementById || !document.getElementsByTagName)         return false;     this.menu = document.getElementById(id);   

jquery 同一页面可多次调用折叠效果代码

jquery 同一页面可多次调用折叠效果代码 点击jq版区块的标题, 会有一个js错误, 那是因为获取js版下的h2时, 我偷了个懒, 把jq的也遍历进去了. 我想, 实际应用中, 也不会有人同一个效果, 一边用js一边用jq吧 //原生js版本 ***** start window.onload=function(){  //共用函数区  var ibase={   //document.getelementbyid   id: function(name){return document.g