三级菜单---zhufeng
<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>无标题文档</title>
<style type="text/css">
li{ margin:5px 0; }
</style>
</head>
<body style="background:#ccc;">
<div id="menu" style="width:240px; background:#fff;">
<ul>
<li><span>第一级第一个</span></li>
<li><span>第一级第二个</span>
<ul>
<li><span>第二级第一个</span></li>
<li><span>第二级第二个</span></li>
<li><span>第二级第三个</span>
<ul>
<li><span>第三级第一个</span></li>
<li><span>第三级第二个</span></li>
<li><span>第三级第三个</span></li>
<li><span>第三级第四个</span></li>
</ul>
</li>
<li><span>第二级第四个</span></li>
</ul>
</li>
<li><span>第一级第三个</span></li>
<li><span>第一级第四个</span>
<ul>
<li><span>第二级第一个</span></li>
<li><span>第二级第二个</span></li>
<li><span>第二级第三个</span></li>
<li><span>第二级第四个</span></li>
</ul>
</li>
</ul>
</div>
</body>
</html>
<script type="text/javascript" src="DOM.js"></script>
<script type="text/ecmascript">
//如果有下一级菜单,则green,如果是终极 blue
var menu=document.getElementById('menu');
var oLis=document.getElementsByTagName('li');
for(var i=0;i<oLis.length;i++){
var oLi=oLis.item(i);
var oSpan=DOM.children(oLi,'span')[0];
var aUl=DOM.children(oLi,'ul');
if(aUl.length){//为true,表示它有下一级菜单
aUl[0].style.display="none";
oSpan.style.backgroundColor="green";
}else{
oSpan.style.backgroundColor="#09f";
}
}
menu.onclick=function(e){
e=e||window.event;
var t=e.target||e.srcElement;
if(t.nodeName!='SPAN') return;
var next=DOM.siblings(t)[0] ;
//Math
if(next){
if(next.style.display=="none"){
next.style.display="block";
}else{
next.style.display="none";
var oUls=next.getElementsByTagName('ul');
for(var i=0;i<oUls.length;i++){
oUls[i].style.display="none";
}
}
}
}
</script>
var DOM={};//命名空间,起分类的作用。单例模式
BOM={};
DOM.children=function (parent,nodeName){
console.log(arguments.callee.caller)//
var a=[];
var childNodes=parent.childNodes;
for(var i=0;i<childNodes.length;i++){
var child=childNodes[i];
if(typeof nodeName=="undefined"&&child.nodeType==1||typeof nodeName=="string"&&child.nodeName==nodeName.toUpperCase()){
a.push(child)
}
}
return a;
}
DOM.siblings=function (ele){
var a=[];
for(var p=ele.previousSibling;p;p=p.previousSibling){
if(p.nodeType==1){
a.unshift(p);
}
}
var n=ele.nextSibling;
while(n){
if(n.nodeType==1){
a.push(n);
}
n=n.nextSibling;
}
return a;
}
DOM.getIndex=function(ele){
var nIndex=0;
var p=ele.previousSibling;
while(p){
if(p.nodeType==1){
nIndex++
}
p=p.previousSibling;
}
return nIndex;
}
DOM.getElesByClass=function (strClass,context){
function byClassName(strClass,eles){
var reg=new RegExp("file://b%22+strclass+%22//b");
var a=[];
for(var i=0;i<eles.length;i++){
var ele=eles[i];
if(reg.test(ele.className)){a.push(ele); }
}
return a;
}
context=context||document;
if(context.getElementsByClassName){
return context.getElementsByClassName(strClass);
}
strClass=strClass.replace(/^ +| +$/g,"");
var aClass=strClass.split(/ +/);
var eles=context.getElementsByTagName("*");
for(var i=0;i<aClass.length;i++){
eles=byClassName(aClass[i],eles);
}
return eles;
}
DOM.addClass=function(ele,strClass){
var reg=new RegExp("file://b%22+strclass+%22//b");
if(!reg.test(ele.className))
ele.className+=" "+strClass;
}
DOM.removeClass=function(ele,strClass){
var reg=new RegExp("file://b%22+strclass+%22//b%22,%22g");
ele.className=ele.className.replace(reg,"");
}
三级菜单---zhufeng的更多相关文章
- python学习笔记(字符串操作、字典操作、三级菜单实例)
字符串操作 name = "alex" print(name.capitalize()) #首字母大写 name = "my name is alex" pri ...
- css三级菜单效果
一个简单实用的css三级菜单效果 <!doctype html> <html> <head> <meta charset="utf-8"& ...
- python成长之路-----day1-----作业(登录程序和三级菜单)
作业: 作业1:用户登录 1)程序说明: a.用户输入密码验证成功然后打印欢迎信息 b.如果密码错误,用户登录失败,提示用户,密码错误 c.用户输入密码错误3次,则用户锁定 d.当用户多次输入不存在的 ...
- Python之路 day2 字典练习题之 三级菜单
#Author:ersa ''' 程序: 三级菜单 要求: 打印省.市.县三级菜单 可返回上一级 可随时退出程序 ''' menu = { '北京':{ '海淀':{ '五道口':{ 'soho':{ ...
- python3 三级菜单
python版本3.5 功能: 1.程序执行显示一级菜单,输入内容进入二级菜单: 2.进入二级菜单后,输入二级菜单内容,进入三级菜单:输入b返回一级菜单: 3.进入三级菜单后,输入b返回二级菜单. # ...
- 用jQuery做一个三级菜单,鼠标移动到二级菜单的选项上,然后再迅速离开后,当鼠标再移动到该一级菜单或其他二级菜单选项,三级菜单也会显示。
用jQuery做一个三级菜单,鼠标移动到二级菜单的选项上,然后再迅速离开后,当鼠标再移动到该一级菜单或其他二级菜单选项,三级菜单也会显示. 原因:在为一个元素绑定hover事件之后,用户把光标移入元素 ...
- day1作业--三级菜单
作业概述: 写一个三级菜单 实现如下功能: (1)可依次选择进入各子菜单 (2)在每一级按“b”都可以返回上一级,按“q"都可以退出 流程图: readme: 简介: three_menu. ...
- python打怪之路【第三篇】:利用Python实现三级菜单
程序: 利用Python实现三级菜单 要求: 打印省.市.县三级菜单 可返回上一级 可随时退出程序 coding: menu = { '北京':{ '朝阳':{ '国贸':{ 'CICC':{}, ' ...
- Python字典实现三级菜单
################################################ # Task Name: 三级菜单 # # Description:打印省.市.县三级菜单 # # 可 ...
随机推荐
- SpringMVC 服务器端验证
1.导入JSR303验证类库Jar包2.在MVC的配置文件中添加<mvc:annotation-driven/>的配置3.在MVC的配置文件中添加验证器的配置4.在接收表单数据的类中添加验 ...
- JUnit 单元测试 配置
选中工程,右键 built path , add liberaries , JUnit , JUnit4 这样就不用每次测试时都在main方法中写了
- Spark.ML之PipeLine学习笔记
地址: http://spark.apache.org/docs/2.0.0/ml-pipeline.html Spark PipeLine 是基于DataFrames的高层的API,可以方便用户 ...
- 3----lua的数据转换及运算符
lua的基本数据类型转换 转换成字符串 tostring( ... ) 可以将布尔类型和数字类型的值转换为字符串类型的值 local num=1; print(type(num)) newNum = ...
- C#正则表达式编程(三):Match类和Group类用法
前面两篇讲述了正则表达式的基础和一些简单的例子,这篇将稍微深入一点探讨一下正则表达式分组,在.NET中正则表达式分组是用Match类来代表的.首先先看一段代码: /// <summary> ...
- 团队作业Week5之团队贡献分的分配
一.团队贡献分的分配规则 首先,我们团队共有5个人,平均每个人50分,所以我们团队的总分为5*50=250,我们先把50分分成以下几份: 序号 贡献类型 权重 分数 1 代码贡献 40% 20 * 5 ...
- winform打开唯一窗体、构造函数传值
制作登入窗体: 制作一个登陆窗体,实现点击按钮关闭此窗体并打开另一个窗体 直接在按钮点击事件中,实例化一个想要打开的窗体 使用show方法打开,并把登陆窗体的visible属性改为false Form ...
- angularjs探秘<一>
首先聊聊angularjs是啥. 首先AngularJS 是一个 JavaScript 框架.(PS:其实就是外部引用的js文件) 所以AngularJS的使用依然是外部引用js文件. 附上引用地址 ...
- 路由器WAN端与LAN端的区别
路由器WAN端与LAN端的区别 WAN的全称为Wide Area Network,即广域网.而LAN的全称为Local Area Network,即局域网.WAN口主要用于连接外部网络,如ADSL.D ...
- [js] 前端性能优化
原文链接:http://www.cnblogs.com/xxcanghai/p/5205998.html 链接:http://www.zhihu.com/question/21658448/answe ...