js tmp

//在chrome中,如果写了如果在<form>标签内写了按钮元素(不管是<input>还是<button>),点击按钮时默认会触发form的get方法提交表单,如果写明提交方式<from method="post">,才用POST方式提交。同时要注意,此<form>的GET或HOST提交方式会覆盖Jquery中的$.ajax()方法。

//调用$.ajax()后异步返回的网页内容不会应用父网页中样式表。

在js中this可以用来代表任何一种当前元素

<head>中的js代码是在html文档之前加载到浏览器里的所以在这里出现document或getElementsByTagName()不合适,应该在window.onload事件中调用js实现的初始化代码,因为当window对象触发onload事件时,document对象已经存在。document是window对象的一个属性。

 

//dom树中往targetElement前加入newElement

function insertAfter(newElement, targetElement)
{ var parent=targetElement.parenNode;
 if(parent.lastChild == targetElement)
  parent.appendChild(newElement);//appendChild()是往父节点加入孩子叶节点,此叶节点成为父节点最后的孩子节点
 else
  parent.insertBefort(newElement, targetElement.nextSibling); //nextSibling是取得同一层次下一个的兄弟节点
}


self指代当前窗口对象,属于window最上层的对象;
location.href 指的是某window对象的URL地址.
self.location.href指当前窗口的URL地址,去掉self默认为当前窗口的URL地址.
一般用于防止外部引用,如果你的网页地址是:
http://www.a.com
别人的是http://www.b.com, 他在他的页面用iframe等框架引用你的http://www.a.com,那么你可以用:
if(top.location.href!=self.location.href){
location.href="http://www.a.com";
}
来转向你的页面,
top指代的是主体窗口,永远指分割窗口最高层次的浏览器窗口。这里top.location.href返回http://www.b.com;self.location.href返回http://www.a.com
if成立,则网页重定向到你的网页,做到防盗用的作用.


下面是一个实用的树形菜单例子:from http://www.jb51.net/article/25167.htm

//----------------------------------------------------------------

<!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>
<title>Help</title>
<meta http-equiv="content-type" content="text/html;charset=gb2312">
<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(tree_pic.gif) -4px -31px no-repeat;}
#root .ren{background:url(tree_pic.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>
</head>
<body>
<ul id="root">
<li>
<label><a href="javascript:;">Router Configuration</a></label>
<ul class="two">
    <li>
    <label><a href="javascript:;">Status</a></label>
    <ul class="two">
        <li>
        <label><a href="javascript:;">二小</a></label>
        <ul class="two">
            <li><label><a href="javascript:;">二年级</a></label></li>
            <li><label><a href="javascript:;">三年级</a></label>
            <ul class="two">
                <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>
            <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>
//----------------------------------------------------------------

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值