Jvascript学习实践案例

 

  • 一个自定义的循环遍历元素文本内容的函数

  该函数可以确保在HTML和XML DOM文档中很好的工作,使用该函数,就能够获取任何元素文本内容了

循环遍历元素文本内容
 1 <html>
 2     <head>
 3         <meta http-equiv="Content-type" content="text/html;charset=gb2312">
 4         <title>一个循环遍历元素文本内容的函数</title>
 5     </head>
 6 <body>
 7     <div id="test">         
 8         <ul>
 9             <li><a href="#">a标签1</a></li>
10             <li><a href="#">a标签2</a></li>    
11             <li><a href="#">a标签3</a></li>
12             <li><a href="#">a标签4</a></li>
13         </ul>
14     </div>
15 <script type="text/javascript">
16     <!--
17     function text(e){
18         //如果传入的是元素,则继续遍历其子元素,否则假定他是一个数组
19         e=e.childNodes || e;
20         var t="";
21         //遍历所有的子节点
22         for(var i=0;i<e.length;i++){
23             if(e[i].nodeType!=1){//如果不是元素节点,则追加其文本值
24                 t+=e[i].nodeValue+"<br>";
25             }else{
26                 t+=text(e[i].childNodes);//否则,继续递归调用
27             }
28         }
29         return t;
30     }
31     var obj=document.getElementById('test');
32     var text=text(obj);
33     document.write(text);
34      //-->
35 </script>
36 </body>
37 </html>

 

  • 通常,我们使用previousSibling,nextSibling,firstChild,lastChild等等来遍历DOM文档,但是,往往会将文本节点也遍历出来,一般情况下,我们不大需要遍历文本节点。所以,这里,我们可以使用自定义的几个函数将previousSibling,nextSibling,firstChild,lastChild封装起来,跳过遍历到的文本节点,而直接取得元素节点
查找节点的几个替代函数
 1 <html>
 2     <head>
 3         <meta http-equiv="Content-type" content="text/html;charset=gb2312">
 4         <title>previousSibling,nextSibling,firstChild,lastChild和parentNode的替代函数</title>
 5 <script type="text/javascript">
 6     <!--
 7     //查找当前元素的前一个兄弟元素节点(注意是元素节点而不是文本节点)
 8     function prev(o){
 9         do{
10             o=o.previousSibling;
11         }while(o.nodeType!=1 && o);//如果前一个兄弟节点是元素节点则跳出循环
12         return o;
13     }
14     //查找当前元素的下一个兄弟元素节点(注意是元素节点而不是文本节点)
15     function next(o){
16         do{
17             o=o.nextSibling;
18         }while(o.nodeType!=1 && o);//如果下一个兄弟节点是元素节点则跳出循环
19         return o;
20     }
21     //查找元素的第一个子元素的函数
22     function first(o){
23         o=o.firstChild;
24         return o.nodeType!=1 && o ? next(o) : o;//如果第一个子节点是元素节点,则返回,否则调用next函数,查找下一个兄弟元素
25     }
26     //查找元素的最后一个子元素的函数
27     function last(o){
28         o=o.lastChild;
29         return o.nodeType!=1 && o ? prev(o) : o;//如果最后一个子节点是元素节点,则返回,否则调用prev函数,查找前一个兄弟元素
30     }
31     //-->
32 </script>
33     </head>
34 <body>
35     <div id="test">
36         <p>大部分的WEB开发者在大多数情况下仅仅需要遍历DOM元素而非相邻的文本节点</p>
37         <p>所以,我们可以自己定义几个函数用于替代<b>previousSibling,nextSibling,firstChild,lastChild和parentNode</b></p>
38         <ul>
39             <li><a href="#">a标签1</a></li>
40             <li><a href="#">a标签2</a></li>    
41             <li><a href="#">a标签3</a></li>
42             <li><a href="#">a标签4</a></li>
43         </ul>
44     </div>
45 <script type="text/javascript">
46     <!--
47     var obj=document.getElementById('test');
48     document.write("使用nextSibling返回的div元素的下一个兄弟节点,①节点类型:"+obj.nextSibling.nodeType+"②节点名称:"+obj.nextSibling.nodeName+"<br>");
49     document.write("使用自定义的next函数返回的div元素的下一个兄弟元素,①节点类型:"+next(obj).nodeType+"②节点名称:"+next(obj).nodeName+"<br>");
50     document.write("使用firstChild返回的div元素的第一个子节点,①节点类型:"+obj.firstChild.nodeType+"②节点名称:"+obj.firstChild.nodeName+"<br>");
51     document.write("使用自定义的first函数返回的div元素的第一个子元素,①节点类型:"+first(obj).nodeType+"②节点名称:"+first(obj).nodeName+"<br>");
52     document.write("使用lastChild返回的div元素的最后一个子节点,①节点类型:"+obj.lastChild.nodeType+"②节点名称:"+obj.lastChild.nodeName+"<br>");
53     document.write("使用自定义的last函数返回的div元素的最后一个子元素,①节点类型:"+last(obj).nodeType+"②节点名称:"+last(obj).nodeName+"<br>");
54     //-->
55 </script>
56 </body>
57 </html>

获取表单对象的 7 种方式

多种获取表单对象的方式
 1 <html>
 2     <head>
 3         <title>获取表单对象的 7 种方式</title>
 4     </head>
 5     <body>
 6     <form name="myform">
 7         <input type="text" value="获取表单对象的 7 种方式" name="test">
 8     </form>
 9     <script type="text/javascript">
10         <!--
11 
12         document.write("方式1:"+document.myform.test.value+"<br>");//经常用
13         
14         document.write("方式2:"+document.forms[0].test.value+"<br>");//通过下标索引访问,较常用
15 
16         document.write("方式3:"+document.forms['myform'].test.value+"<br>"); //方式3和方式4可以切换的,这是源于js访问对象的方式可以采用数组形式来访问的缘故
17         document.write("方式4:"+document.forms.myform.test.value+"<br>");
18 
19         document.write("方式5:"+document['myform'].test.value+"<br>");
20 
21         document.write("方式6:"+document.forms.item(0).test.value+"<br>");//注意 是item(),不是item[]
22         document.write("方式7:"+document.forms.item('myform').test.value+"<br>");
23     //-->
24     </script>
25     </body>
26 </html>

 

  • 使用javascript实现全选,反选,全不选的功能
View Code
 1 <html>
 2     <head>
 3         <title>全选,反选,全不选</title>
 4     </head>
 5     <body>
 6         <script type="text/javascript">
 7         <!--
 8         for (var i=0;i<20;i++){
 9             document.write('测试'+(i+1)+'<input type="checkbox" name="sel[]"><br>');
10         }
11         var o=document.getElementsByName("sel[]");//全局变量
12         //全选
13         function selall(){    
14             for(var i=0;i<o.length;i++){
15                 o[i].checked="true";
16             }
17         }
18         //全不选
19         function noselall(){
20             for(var i=0;i<o.length;i++){
21                 o[i].checked="";
22             }
23         }
24         //反选
25         function invert(){
26             for(var i=0;i<o.length;i++){
27                 if(o[i].checked==true){
28                     o[i].checked="";
29                 }else{
30                     o[i].checked=true;
31                 }
32                 
33             }
34         }
35         //-->
36         </script>
37         <a href="javascript:selall(this)">全选</a>
38         <a href="javascript:noselall(this)">全不选</a>
39         <a href="javascript:invert(this)">反选</a>
40     </body>
41 </html>
  • 鼠标移上去,显示子栏目列表

显示隐藏菜单
 1 <html>
 2     <head>
 3         <title>操作菜单</title>
 4         <style>
 5             li{
 6                 list-style:none;            
 7             }
 8             #menu ul li{
 9                 float:left;
10                 width:75px;
11                 height:30px;
12                 text-align:center;
13             }
14             #submenu{
15                 clear:both;
16             }
17             #submenu ul li{
18                 background:#888;
19                 width:236px;
20             }
21             #submenu ul li a{
22                 color:#fff;
23                 text-decoration:none;
24             }
25             .highlight{
26                 background:#888;
27 
28             }
29         </style>
30     </head>
31     <body>
32         <div id="menu">
33             <ul>
34                 <li onmouseover="change(0)" class="highlight">Menu1</li>
35                 <li onmouseover="change(1)">Menu2</li>
36                 <li onmouseover="change(2)">Menu3</li>        
37             </ul>
38         </div>
39         <div id="submenu">
40             <ul>
41                 <li>
42                     <a href="#">子菜单1</a><br>
43                     <a href="#">子菜单1</a><br>
44                     <a href="#">子菜单1</a><br>
45                     <a href="#">子菜单1</a><br>
46                 </li>
47                 <li style="display:none">
48                     <a href="#">子菜单2</a><br>
49                     <a href="#">子菜单2</a><br>
50                     <a href="#">子菜单2</a><br>
51                     <a href="#">子菜单2</a><br>
52                 </li>
53                 <li style="display:none">
54                     <a href="#">子菜单3</a><br>
55                     <a href="#">子菜单3</a><br>
56                     <a href="#">子菜单3</a><br>
57                     <a href="#">子菜单3</a><br>
58                 </li>                    
59 
60             </ul>
61         </div>
62     <script type="text/javascript">
63         <!--
64         var menu=document.getElementById("menu").getElementsByTagName("li");
65         var submenu=document.getElementById('submenu').getElementsByTagName('li');
66         function change(num){
67             for (var i=0;i<menu.length;i++){
68                 if(i==num){
69                     menu[num].className="highlight";
70                     submenu[num].style.display="block";
71                 }else{
72                     menu[i].className="";
73                     submenu[i].style.display="none";                    
74                 }
75             }
76             
77         }
78     //-->
79     </script>
80     </body>
81 </html>

 

  • 通过for...in循环语句,可以遍历出某个对象中的属性

比如,我们想要看下document对象中的所有属性名和属性值,可以使用如下所示的代码:

View Code
<html>
    <head>
        <title>遍历document文档对象的所有属性</title>
    </head>
    <body>
    <script type="text/javascript">
    <!--
        for (var pro in document){
            document.write("document."+pro+"="+document[pro]+"<br>");
        }
    //-->
    </script>
    </body>
</html>

 同理,我们也可以用以上方法遍历window对象,location对象,history对象等的属性,当然,也可以用来遍历自定义对象的属性

 

 

 

 

 

多得多

posted @ 2012-06-22 09:12  曾是土木人  阅读(610)  评论(0编辑  收藏  举报