用XSLT轻松实现树形折叠导航栏

怕黑的小B孩

怕黑的小B孩

2016-02-19 14:46

每个人都希望每天都是开心的,不要因为一些琐事扰乱了心情还,闲暇的时间怎么打发,关注图老师可以让你学习更多的好东西,下面为大家推荐用XSLT轻松实现树形折叠导航栏,赶紧看过来吧!

展开和折叠其实就是显示或不显示(display:none or block)它与可见与不可见(visible or invisible)是有区别的, 前者不在页面预留空间。 这个toggle函数完成两个功能, 改变TR原来的Hidden属性, 使原来不显示的显示; 改变IMG的src属性, 更改图片。

toggle.js

function toggle(id)
{
var thisRow = document.all.item(id);
if (thisRow)
{
if (thisRow.getAttribute("Expanded") == 'yes')
{
thisRow.setAttribute("Expanded", "no");
thisRow.children(0).children(0).children(0).src = "images/bs.gif";

var allRows = document.all.tags("TR");
for (var i=1; i allRows.length; i++)
{
var row = allRows[i];
if (row.getAttribute("AncestorID") == id)
{
if (row.getAttribute("Expanded") == 'yes') {
toggle(row.getAttribute("id"));
}
row.className = 'Navigator-Hidden';
}
}
thisRow.className = 'Navigator';
}
else
{
thisRow.setAttribute("Expanded", "yes");
thisRow.children(0).children(0).children(0).src = "images/bo.gif";

var allRows = document.all.tags("TR");
var depth = parseInt(thisRow.getAttribute("Depth"));
for (var i=1; i allRows.length; i++)
{
var row = allRows[i];
if (row.getAttribute("AncestorID") == id &&
parseInt(row.getAttribute("Depth")) == depth + 1 )
{
row.className = 'Navigator';
}
}
}
}
}

到此结束。

诚然这个TOC的功能还是最基本的, 例如我还未做内容和目录的同步,其中有的地方还可以修改, 对xml和xsl文件可以进一步瘦身。 不过对一般用户来讲, 这已经足够了。
真诚希望这篇文章能对您有所启发、有所帮助, 以后做出更酷、更快、更方便、功能更强的TOC。

(本文来源于图老师网站,更多请访问http://m.tulaoshi.com/webkaifa/)

展开更多 50%)
分享

猜你喜欢

用XSLT轻松实现树形折叠导航栏

Web开发
用XSLT轻松实现树形折叠导航栏

用XSLT轻松实现树形折叠导航栏(4)

Web开发
用XSLT轻松实现树形折叠导航栏(4)

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

用XSLT轻松实现树形折叠导航栏(3)

Web开发
用XSLT轻松实现树形折叠导航栏(3)

html教程:用tabIndex轻松实现网页导航

Web开发
html教程:用tabIndex轻松实现网页导航

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

JQuery 浮动导航栏实现代码

Web开发
JQuery 浮动导航栏实现代码

怎样用PPT制作网站导航栏

电脑入门
怎样用PPT制作网站导航栏

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

开 始 つ仰望幸福 - QQ图案分组

开 始 つ仰望幸福 - QQ图案分组

SQL Server备份出错及应对措施

SQL Server备份出错及应对措施
下拉加载更多内容 ↓