图书订购系统前端设计

<%@ page language="java" contentType="text/html; charset=gb2312"%>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html;charset=gb2312">
<title>图书订购系统</title>
</head>
<style type="text/css">
body {
	margin: 0;
	padding: 0;
/* 	font: 12px/1.5 Tahoma, Helvetica, Arial, sans-serif; */
}

ul
,
li
,
{
margin
:
0;


padding
:
0;


}
ul {
	list-style: none;
}

#root {
	margin: 10px;
	width: 200px;
	overflow: hidden;
}

#root li {
	line-height: 25px;
}

#root .rem {
	padding-left: 16px;
}

#root .add {
	background: url(/upload/201010/20101031213041133.gif) -4px -31px
		no-repeat;
}

#root .ren {
	background: url(/upload/201010/20101031213041133.gif) -4px -7px
		no-repeat;
}

#root li a {
	color: #666666;
	padding-left: 5px;
	outline: none;
	blr: expression(this.onFocus = this.blur ());
}

#root li input {
	vertical-align: middle;
	margin-left: 5px;
}

#root .two {
	padding-left: 20px;
	display: none;
}
</style>

<body>
	<ul id="root">
		<li><label><a href="javascript:;">123</a></label>
			<ul class="two">
				<li><label><a href="javascript:;">shenyang</a></label>
					<ul class="two">
						<li><label><input type="checkbox" value="123456"><a
								href="#javascript:;">二小</a></label>
							<ul class="two">
								<li><label><input type="checkbox" value="123456"><a
										href="#javascript:;">二年级</a></label></li>
								<li><label><input type="checkbox" value="123456"><a
										href="#javascript:;">三年级</a></label>
									<ul class="two">
										<li><label><input type="checkbox" value="123456"><a
												href="#javascript:;">一班</a></label>
											<ul class="two">
												<li><label><input type="checkbox"
														value="123456"><a href="#javascript:;">张三</a></label></li>
												<li><label><input type="checkbox"
														value="123456"><a href="#javascript:;">王五</a></label></li>
											</ul></li>
										<li><label><input type="checkbox" value="123456"><a
												href="#javascript:;">实验班</a></label></li>
									</ul></li>
							</ul></li>
					</ul></li>
				<li><label><a href="javascript:;">抚顺市</a></label>
					<ul class="two">
						<li><label><input type="checkbox" value="123456"><a
								href="#javascript:;">二小</a></label></li>
						<li><label><input type="checkbox" value="123456"><a
								href="#javascript:;">一中</a></label></li>
					</ul></li>
			</ul></li>
	</ul>
	<script type="text/javascript">
		function addEvent(el, name, fn) {//绑定事件 
			if (el.addEventListener)
				return el.addEventListener(name, fn, false);
			return el.attachEvent('on' + name, fn);
		}
		function nextnode(node) {//寻找下一个兄弟并剔除空的文本节点 
			if (!node)
				return;
			if (node.nodeType == 1)
				return node;
			if (node.nextSibling)
				return nextnode(node.nextSibling);
		}
		function prevnode(node) {//寻找上一个兄弟并剔除空的文本节点 
			if (!node)
				return;
			if (node.nodeType == 1)
				return node;
			if (node.previousSibling)
				return prevnode(node.previousSibling);
		}
		function parcheck(self, checked) {//递归寻找父亲元素,并找到input元素进行操作 
			var par = prevnode(self.parentNode.parentNode.parentNode.previousSibling), parspar;
			if (par && par.getElementsByTagName('input')[0]) {
				par.getElementsByTagName('input')[0].checked = checked;
				parcheck(par.getElementsByTagName('input')[0], sibcheck(par
						.getElementsByTagName('input')[0]));
			}
		}
		function sibcheck(self) {//判断兄弟节点是否已经全部选中 
			var sbi = self.parentNode.parentNode.parentNode.childNodes, n = 0;
			for (var i = 0; i < sbi.length; i++) {
				if (sbi[i].nodeType != 1)//由于孩子结点中包括空的文本节点,所以这里累计长度的时候也要算上去 
					n++;
				else if (sbi[i].getElementsByTagName('input')[0].checked)
					n++;
			}
			return n == sbi.length ? true : false;
		}
		addEvent(
				document.getElementById('root'),
				'click',
				function(e) {//绑定input点击事件,使用root根元素代理 
					e = e || window.event;
					var target = e.target || e.srcElement;
					var tp = nextnode(target.parentNode.nextSibling);
					switch (target.nodeName) {
					case 'A'://点击A标签展开和收缩树形目录,并改变其样式会选中checkbox 
						if (tp && tp.nodeName == 'UL') {
							if (tp.style.display != 'block') {
								tp.style.display = 'block';
								prevnode(target.parentNode.previousSibling).className = 'ren'
							} else {
								tp.style.display = 'none';
								prevnode(target.parentNode.previousSibling).className = 'add'
							}
						}
						break;
					case 'SPAN'://点击图标只展开或者收缩 
						var ap = nextnode(nextnode(target.nextSibling).nextSibling);
						if (ap.style.display != 'block') {
							ap.style.display = 'block';
							target.className = 'ren'
						} else {
							ap.style.display = 'none';
							target.className = 'add'
						}
						break;
					case 'INPUT'://点击checkbox,父亲元素选中,则孩子节点中的checkbox也同时选中,孩子结点取消父元素随之取消 
						if (target.checked) {
							if (tp) {
								var checkbox = tp.getElementsByTagName('input');
								for (var i = 0; i < checkbox.length; i++)
									checkbox[i].checked = true;
							}
						} else {
							if (tp) {
								var checkbox = tp.getElementsByTagName('input');
								for (var i = 0; i < checkbox.length; i++)
									checkbox[i].checked = false;
							}
						}
						parcheck(target, sibcheck(target));//当孩子结点取消选中的时候调用该方法递归其父节点的checkbox逐一取消选中 
						break;
					}
				});
		window.onload = function() {//页面加载时给有孩子结点的元素动态添加图标 
			var labels = document.getElementById('root').getElementsByTagName(
					'label');
			for (var i = 0; i < labels.length; i++) {
				var span = document.createElement('span');
				span.style.cssText = 'display:inline-block;height:18px;vertical-align:middle;width:16px;cursor:pointer;';
				span.innerHTML = ' '
				span.className = 'add';
				if (nextnode(labels[i].nextSibling)
						&& nextnode(labels[i].nextSibling).nodeName == 'UL')
					labels[i].parentNode.insertBefore(span, labels[i]);
				else
					labels[i].className = 'rem'
			}
		}
	</script>
</body>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值