DOM&JavaScript示例&练习

以下示例均为html文件,保存至本地就可直接用浏览器打开以查看效果\(^o^)/~

练习一:设置新闻字体

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5 <title>字体样式选择</title>
  6     <style type="text/css">
  7         a:link,a:visited{
  8             text-decoration:none;//取消下划线
  9         }
 10         #newsText{
 11             border: #CC0033 double 2px;
 12             width:800px;
 13         }
 14         p{
 15             text-indent:2em;//首行缩进
 16         }
 17         .max{
 18             font-size:36px;
 19             color:#666699;
 20         }
 21         .mid{
 22             font-size:18px;
 23             color:#6666FF;
 24         }
 25         .min{
 26             font-size:13px;
 27             color:#3399FF;
 28         }
 29     </style>
 30 </head>
 31 <body>
 32     <script type="text/javascript">
 33         function changeFont(className){
 34             var divNode = document.getElementById("newsText");
 35             divNode.className = className;
 36         }
 37     </script>
 38     <h2 style="color:#FF0000">【念念有余】马云的达摩院想干嘛?</h2>
 39     <a href="javascript:void(0)" onclick="changeFont('max')">大字体</a>
 40     <a href="javascript:void(0)" onclick="changeFont('mid')">中字体</a>
 41     <a href="javascript:void(0)" onclick="changeFont('min')">小字体</a>
 42     <hr  style="border:#99FF00 solid 1px"/>
 43     <div id="newsText">
 44         <p>
 45         两个着传统武打装扮的年轻人,斜步蹲身,一起擎出一个硕大的牌匾来,中间三个遒劲有力的字正是“达摩院”。
 46         </p>
 47         <p><img src="http://p0.ifengimg.com/pmop/2017/1014/BC710B82FEC535D27C6728240C1B20ED367433A7_size34_w500_h333.jpeg"/></p>
 48         <p>马云说,要搞电商,于是有了阿里巴巴;马云说,要有网上支付,于是有了支付宝,有了蚂蚁金服;
 49         马云说,要有云计算,于是到处是云计算。现在马云说,要有达摩院,于是,达摩院的牌子挂起来了。
 50         </p>
 51         <p>
 52         10月11日开幕的2017云栖大会吸引了4万人之众,人们把这场大会当做一场嘉年华,会场外,男人女人们,
 53         像游客一样撑起自拍杆,阿里帝国已经大到了令人咋舌的地步,批量创造着千万富翁。马云称阿里已经是世界上第21大经济体,
 54         未来要做第5大经济体。大会上人们记得最真切的是有“外星人”之称的马云说要投资1000亿元建立达摩院。达摩院就是实验室。
 55         马云为达摩院命名,当年马云同样为天猫命名。
 56         </p>
 57         <p>
 58         “达摩院”这个名字很有阿里特色,达摩是一个佛教人物,民间常称其为达摩祖师,南印度人,自称佛传禅宗第二十八祖,
 59         为中国禅宗始祖。负责达摩院的是阿里CTO张建锋,诨名行癫。马云号风清扬,阿里有头脸的人物都有一个江湖诨名,
 60         就跟梁山泊一百零八将一样,连诨名都没有,估计这人在阿里也就没什么地位。
 61         </p>
 62         <p>
 63         如果将一些典故或者武侠背景联系起来,就会明白,达摩院其实是藏经阁,这里将会发明各种必杀之技,未来也不知道会怎么样,
 64         但大家都明白,谁掌握了技术,就会像大航海时代的殖民者一样,以少胜多。
 65         </p>
 66         <p>
 67         但是必杀技哪里会那么简单?到了一定程度就会有瓶颈,一定不是现有水平的修修补补,而是牵涉到基础科学、基础技术,
 68         越是处于领先地位的企业,越是走得靠前的企业,他们离天花板就越近,看得越清晰。这就是为什么国际顶尖企业会做顶尖研究,
 69         他们有财力有眼力,还有能力。
 70         </p>
 71         <p>
 72         “达摩院”首批公布的研究领域包括:量子计算、机器学习、基础算法、网络安全、视觉计算、自然语言处理、
 73         下一代人机交互、芯片技术、传感器技术、嵌入式系统等,涵盖机器智能、智联网、金融科技等多个产业领域。
 74         名目繁多,似乎无所不包,这里面可以看到马云的野心,这也显示了马云和阿里一个非常重要变化——由“术”向“道”。
 75         </p>
 76         <p>
 77         马云说,阿里成立七八年的时候,他坚决反对公司有任何研究室、实验室的,因为当时阿里是一个初创公司,
 78         公司在还没有立足之前就考虑研发是大灾难。阿里的做法一直是问题导向,遇到什么问题,需要什么,就组织工作人员去攻关。
 79         </p>
 80         <p>
 81         马云多次说过,如果他是技术人员,一开始就知道会有这么多难题,估计就会退缩,就不会有现在的阿里巴巴、蚂蚁金服。
 82         阿里现在不仅是遇到问题就组织科研人员去攻关,而是四处开拓疆土,看看有什么领域比较有机会。前者目的性很强,是问题导向,
 83         后者则是四处撒网,花钱多但不一定有结果。
 84         </p>
 85         <p>
 86         像这些比较基础的科研,一般是高校和科研院所承担,这些机构背后买单者是政府,这是政府要承担的职能之一,
 87         因为这些研发大多是没有收益的,但对社会会比较有帮助,让单个企业承担的成本太高。这表明阿里已经不再担忧生存问题,愿意承担一部分政府承担的责任。
 88         </p>
 89         <p>
 90         有不少人认为,阿里这次投入,只是一场作秀,科技不可能拔毛助长,不可能投进去很多钱,就能大跃进。
 91         不过公众应该去想一想,像阿里这样精明的企业,怎么会愿意做折本买卖?
 92         </p>
 93         <p>
 94         阿里现在的规模已足够大,护城墙也足够高,危险来自未来,如果不下足功夫研究,一旦被竞争对手掌握,
 95         就有可能被秒杀。即使像腾讯这样规模的还面临从QQ到微信的惊险一跃,就跟苏宁和京东的竞争一样,一旦落后下去,就很难追赶了。
 96         </p>
 97         <p>
 98         马云说贝尔、IBM的实验室曾经创造辉煌,可这种工业时代的实验室模式已经没落了。他认为达摩院科研的目标不仅仅是FUN,
 99         也不仅是PROFIT,而是问题导向,以解决问题为目标。
100         </p>
101         <p>
102         达摩院似乎是一个独立经营个体,就像很多研发机构也能最终上市一样,马云要求达摩院能够独立经营维持下去。至于方法,
103         外人还很难猜测,科研机构一般要靠政府拨款,或者慈善捐助,当然也可以是订单式研发,转让专利技术。
104         </p>
105         <p>
106         有很多技术是得益于那些大企业的研发,比如数码相机,即使研发者被革了命,也是为人类做了贡献。应该记住的是,
107         即使那些传统企业没落了,他们留下的科研仍在;即使那些富豪不在了,他们留下的研究机构还在;比如卡耐基捐助的卡内基·梅隆大学,
108         洛克菲勒捐助的洛克菲勒大学,还有洛克菲勒基金会对科学所做的贡献。
109         </p>
110         <p>
111         (编辑:刘骏)
112     </div>
113 </body>
114 </html>
View Code

练习二:展开&闭合列表

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>展开&闭合列表 </title>
 6 <style type="text/css">
 7     dl{
 8         font:color:#6699CC;
 9         width:300px;
10         height:18px;
11     }
12     dl dt{
13         font-weight:bold;
14         color:Green;
15         cursor:pointer; //设置手势
16     }
17     dl dd{
18         margin:0px;
19     }
20     /*    //预定义样式:便于标签样式的动态加载*/
21     .open{
22         height:130px;/*不设置的话,文字会重叠*/
23         overflow:visible;
24     }
25     .close{
26         overflow :hidden;
27     }    
28 </style>
29 </head>
30 
31 <body>
32     <script type="text/javascript">
33         function show() {
34             var dtNode = window.event.srcElement;
35             var dlNode = dtNode.parentNode;
36             var dlNodes = document.getElementsByTagName("dl");
37             for (var i = 0; i < dlNodes.length; i++) {
38                 if (dlNodes[i] == dlNode) {       //判断是否是当前点击的dl
39                     if (dlNodes[i].className == "open") {
40                         dlNodes[i].className = "close";
41                     }
42                     else {
43                         dlNodes[i].className = "open";
44                     }
45                 }
46                 else {
47                     dlNodes[i].className = "close";
48                 }
49             }
50         }
51     </script>
52     <dl class="close">
53         <dt onclick="show()">
54         列表一
55         </dt>
56         <dd>列表内容sasasacsa</dd>
57         <dd>列表内容dafrfgrve</dd>
58         <dd>列表内容saspasl;a,</dd>
59         <dd>列表内容dsd9qwklms</dd>
60         <dd>列表内容sajsoiaya</dd>
61     </dl>
62     <dl class="close">
63         <dt  onclick="show()">
64         列表二
65         </dt>
66         <dd>列表内容sasasacsa</dd>
67         <dd>列表内容dafrfgrve</dd>
68         <dd>列表内容saspasl;a,</dd>
69         <dd>列表内容dsd9qwklms</dd>
70         <dd>列表内容sajsoiaya</dd>
71     </dl>
72     <dl class="close">
73         <dt onclick="show()">
74         列表三
75         </dt>
76         <dd>列表内容sasasacsa</dd>
77         <dd>列表内容dafrfgrve</dd>
78         <dd>列表内容saspasl;a,</dd>
79         <dd>列表内容dsd9qwklms</dd>
80         <dd>列表内容sajsoiaya</dd>
81     </dl>
82 </body>
83 </html>
View Code

练习三:自动创建表格

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>自动创建表格</title>
 6 <link rel="stylesheet" type="text/css" href="table.css" />
 7 </head>
 8 
 9 <body>
10     <script type="text/javascript">
11         var tabNum = 1;
12         function creTable(){
13             /*原始方法:
14             //创建表格节点
15             var tabNode = document.createElement("table");
16             //创建tbody节点
17             var tbdNode = document.createElement("tbody");
18             //创建行节点tr
19             var trNode = document.createElement("tr");
20             //创建单元格节点td
21             var tdNode = document.createElement("td");
22             tdNode.innerHTML = "单元格内容";
23             
24             //让这些节点具有层次关系:组成一个表
25             tabNode.appendChild(tbdNode);
26             tbdNode.appendChild(trNode);
27             trNode.appendChild(tdNode);
28             */
29             
30             //新方法:使用表格节点自带的方法:insertRow()
31             //获取行列值
32             var rowNode = document.getElementsByTagName("input")[0];
33             var celNode = document.getElementsByTagName("input")[1];
34             if(rowNode.value==""|| rowNode.value==""){
35                 alert("数据不能为空!");
36             }
37             else{
38                 var divNode = document.getElementsByTagName("div")[0];
39                 var x = rowNode.value;
40                 var y = celNode.value;
41                 //添加说明
42                 var text = document.createElement("div");
43                 text.innerHTML = "[表格"+tabNum+"]:"+x+"x"+y;
44                 tabNum++;
45                 divNode.appendChild(text);
46                 
47                 //添加表格
48                 var tabNode = document.createElement("table");
49                 for(var i=1;i<=x;i++){//插入x行
50                     var trNode = tabNode.insertRow();
51                     for(var j=1;j<=y;j++){//插入单元格:即列
52                         var tdNode = trNode.insertCell();
53                     }
54                 }
55                 tabNode.id = tabNum-1;
56                 divNode.appendChild(tabNode);
57                 //添加一条下划线
58                 var line = document.createElement("hr");
59                 divNode.appendChild(line);
60             }
61         }
62         //删除指定表格(该方法存在缺陷:没有删除表格上方的说明文字;没有做健壮性判断)
63         function delTable(){
64             var tableNode = document.getElementsByTagName("input")[3];
65             if(tableNode.value==""){
66                 alert("数据不能为空!");
67             }
68             else{
69                 var tabId = tableNode.value;
70                 var tabnumNode = document.getElementById(tabId);
71                 tabnumNode.parentNode.removeChild(tabnumNode);
72             }
73         }
74     </script>
75     &nbsp;&nbsp;&nbsp;&nbsp;行:<input type="text" name="rownum"/>
76     列:<input type="text" name="colnum"/>
77     <input type="button" value="创建" onclick="creTable()" />
78     <br/>
79     表格:<input type="text" name="tabnum"/>
80     <input type="button" value="删除" onclick="delTable()" />
81     <hr/>
82     <div></div>
83 </body>
84 </html>
View Code

css文件:文件名为table.css

 1 /* CSS Document */
 2 table{
 3     border:#33ff11 1px solid;
 4     width:300px;
 5     border-collapse:collapse;
 6 }
 7 table td{
 8     border:#663366 1px solid;
 9     padding:10px;
10 }
11 table th{
12     border:#6633ff 1px solid;
13     padding:10px;
14     background-color:rgb(100,200,300);
15 }
tables.css 

练习四:表格行高亮

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>行颜色间隔并高亮</title>
 6 <link rel="stylesheet" href="table.css" />
 7 <style type="text/css">
 8     .one{
 9         background:#99CCFF;
10     }
11     .two{
12         background:#FFFF99;
13     }
14     .over{
15         background-color:#FF0000;
16     }
17 </style>
18 <script type="text/javascript">
19     var name;//记录行的classname
20     /*设置行属性和行为*/
21     function setRows(){
22         //获取表格对象
23         var tabNode = document.getElementById("infoTab");
24         //获取行
25         var rowsNode = tabNode.rows;
26         //从第二行开始遍历(不算表头)
27         for(var i=1;i<rowsNode.length;i++){
28             if(i%2 == 1)
29                 rowsNode[i].className = "one";
30             else
31                 rowsNode[i].className = "two";
32             
33             //设置完颜色,给行添加时间(行为)
34             rowsNode[i].onmouseover = function(){
35                 name = this.className;
36                 this.className = "over";//高亮
37             }
38             rowsNode[i].onmouseout = function(){
39                 this.className = name;//还原
40             }
41         }
42     }
43     //在加载完成后调用方法:
44     window.onload = function(){
45         setRows();
46     }
47 </script>
48 </head>
49 <body>
50     <table id="infoTab">
51         <tr>
52             <th>姓名</th>
53             <th>年龄</th>
54             <th>地址</th>
55         </tr>
56         <tr>
57             <td>张三</td>
58             <td>24</td>
59             <td>上海</td>
60         </tr>
61         <tr>
62             <td>李四</td>
63             <td>21</td>
64             <td>北京</td>
65         </tr>
66         <tr>
67             <td>王五</td>
68             <td>34</td>
69             <td>天津</td>
70         </tr>
71         <tr>
72             <td>小明</td>
73             <td>27</td>
74             <td>石家庄</td>
75         </tr>
76         <tr>
77             <td>小红</td>
78             <td>24</td>
79             <td>黑龙江</td>
80         </tr>
81         <tr>
82             <td>小强</td>
83             <td>23</td>
84             <td>合肥</td>
85         </tr>
86         <tr>
87             <td>诗朗诵</td>
88             <td>35</td>
89             <td>杭州</td>
90         </tr>
91         <tr>
92             <td>贝尔</td>
93             <td>38</td>
94             <td>纽约</td>
95         </tr>
96     </table>
97 </body>
98 </html>
View Code

练习五:表格排序

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5 <title>表格排序</title>
  6 <link rel="stylesheet" type="text/css" href="table.css" />
  7 <style type="text/css">
  8     .over{
  9         background-color:#FF0000;
 10     }
 11     th a:link,th a:visited{
 12         text-decoration:none;
 13         color:#0000FF;
 14     }
 15 </style>
 16 <script type="text/javascript">
 17     var name;//记录行的classname
 18     /*设置行属性和行为*/
 19     function setRows(){
 20         //获取表格对象
 21         var tabNode = document.getElementById("infoTab");
 22         //获取行
 23         var rowsNode = tabNode.rows;
 24         //从第二行开始遍历(不算表头)
 25         for(var i=1;i<rowsNode.length;i++){
 26             //给行添加时间(行为)
 27             rowsNode[i].onmouseover = function(){
 28                 name = this.className;
 29                 this.className = "over";//高亮
 30             }
 31             rowsNode[i].onmouseout = function(){
 32                 this.className = name;//还原
 33             }
 34         }
 35     }
 36     //在加载完成后调用方法:
 37     window.onload = function(){
 38         setRows();
 39     }
 40 </script>
 41 <script type="text/javascript">
 42     /*给表格排序
 43     1、获取需要排序的行对象数组
 44     2、按指定规则排序
 45     3、将排好序的数组添加回表格
 46     */
 47     var flag = true;
 48     function sortTab(){
 49         //获取表格对象
 50         var tabNode = document.getElementById("infoTab");
 51         //获取行
 52         var rowsNode = tabNode.rows;
 53         //定义临时容器存储要排序的行对象(其实存的是地址,排序的时候是排的行对象)
 54         var tempRows = [];
 55         for(var i=1;i<rowsNode.length;i++){
 56             tempRows[i-1] = rowsNode[i];
 57         }
 58         //对临时容器排序
 59         if(flag){
 60             mySort(tempRows);
 61             //将排序的行对象添加回表格
 62             for(var x=0;x<tempRows.length;x++){
 63                 tempRows[x].parentNode.appendChild(tempRows[x]);
 64             }
 65             flag = false;
 66         }
 67         else{
 68             mySort(tempRows);
 69             //将排序的行对象添加回表格
 70             for(var x=tempRows.length-1;x>=0;x--){
 71                 tempRows[x].parentNode.appendChild(tempRows[x]);
 72             }
 73             flag = true;
 74         }
 75     }
 76     //数组排序
 77     function mySort(arr){
 78         for(var x=0;x<arr.length-1;x++)
 79             for(var y=x+1;y<arr.length;y++){
 80                 if(arr[x].cells[1].innerHTML < arr[y].cells[1].innerHTML){
 81                     var temp = arr[x];
 82                     arr[x] = arr[y];
 83                     arr[y] = temp;
 84                 }    
 85             }
 86     }
 87     
 88 </script>
 89 </head>
 90 <body>
 91     <table id="infoTab">
 92         <tr>
 93             <th>姓名</th>
 94             <th><a href="javascript:void(0)" onclick="sortTab()">年龄</a></th>
 95             <th>地址</th>
 96         </tr>
 97         <tr>
 98             <td>张三</td>
 99             <td>24</td>
100             <td>上海</td>
101         </tr>
102         <tr>
103             <td>李四</td>
104             <td>21</td>
105             <td>北京</td>
106         </tr>
107         <tr>
108             <td>王五</td>
109             <td>34</td>
110             <td>天津</td>
111         </tr>
112         <tr>
113             <td>小明</td>
114             <td>27</td>
115             <td>石家庄</td>
116         </tr>
117         <tr>
118             <td>小红</td>
119             <td>24</td>
120             <td>黑龙江</td>
121         </tr>
122         <tr>
123             <td>小强</td>
124             <td>23</td>
125             <td>合肥</td>
126         </tr>
127         <tr>
128             <td>诗朗诵</td>
129             <td>35</td>
130             <td>杭州</td>
131         </tr>
132         <tr>
133             <td>贝尔</td>
134             <td>38</td>
135             <td>纽约</td>
136         </tr>
137     </table>
138 </body>
139 </html>
View Code

练习六:全选&全不选&删除选择

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5 <title>全选&反选</title>
  6 <style type="text/css">
  7     table{
  8         border:#33ff11 1px solid;
  9         width:650px;
 10         border-collapse:collapse;
 11         text-align:center;
 12     }
 13     table td{
 14         border:#663366 1px solid;
 15         padding:10px;
 16     }
 17     table th{
 18         border:#666666 1px solid;
 19         padding:10px;
 20         background-color:rgb(100,200,300);
 21     }
 22     .one{
 23         background-color:#CCCCFF;
 24     }
 25     .two{
 26         background-color:#FFFFCC;
 27     }
 28     .lastline{
 29         background-color:#0099FF;
 30     }
 31     .over{
 32         background:#CC3300;
 33     }
 34     h1{
 35         color:#00FF99;
 36     }
 37 </style>
 38 <script type="text/javascript">
 39     var name;
 40     //行间隔颜色设置
 41     function setRows(){
 42         var otabNode = document.getElementById("mailTab");
 43         var orowNodes = otabNode.rows;
 44         
 45         for(var x=1;x<orowNodes.length-1;x++){
 46             if(x%2 == 1)
 47                 orowNodes[x].className = "one";
 48             else
 49                 orowNodes[x].className = "two";
 50             //事件
 51             orowNodes[x].onmouseover = function(){
 52                 name = this.className;
 53                 this.className = "over";//高亮
 54             }
 55             orowNodes[x].onmouseout = function(){
 56                 this.className = name;//还原
 57             }
 58         }
 59         orowNodes[x].className = "lastline";
 60     }
 61     //文档加载后执行:
 62     window.onload = function(){
 63         setRows();
 64     }
 65     
 66     //复选框的全选动作
 67     function checkAll(node){
 68         //获取所有复选框
 69         var mailNodes = document.getElementsByName("mail");
 70         for(var x=0;x<mailNodes.length;x++){
 71             mailNodes[x].checked = node.checked;
 72         }
 73     }
 74     //单击按钮事件
 75     function checkAllByBut(num){
 76         var mailNodes = document.getElementsByName("mail");
 77         for(var x=0;x<mailNodes.length;x++){
 78             if(num >= 1)//单选
 79                 mailNodes[x].checked = !mailNodes[x].checked;
 80             else//全不选
 81                 mailNodes[x].checked = num;
 82         }
 83     }
 84     //删除
 85     function delMails(){
 86         var mailNodes = document.getElementsByName("mail");
 87         if(!confirm("是否删除所选邮件信息?"))
 88             return;
 89         for(var x=0;x<mailNodes.length;x++){
 90             if(mailNodes[x].checked){
 91                 var rowNode = mailNodes[x].parentNode.parentNode;//获取行
 92                 rowNode.parentNode.removeChild(rowNode)
 93                 x--;//注意:这很关键,因为一旦remove,数组长度变短,但x却在自增,所以每remove一次需要自减一次
 94             }
 95             setRows();//更新行设置
 96         }
 97     }
 98 </script>
 99 </head>
100 <body>
101     <h1>email管理</h1>
102     <table id="mailTab">
103         <tr>
104             <th><input type="checkbox" name="all" onclick="checkAll(this)"/>全选</th>
105             <th>发件人</th>
106             <th>邮件名称</th>
107             <th>邮件附属信息</th>
108         </tr>
109         <tr>
110             <td><input type="checkbox" name="mail"/></td>
111             <td>张三</td>
112             <td>1oaoisasja@mail.com</td>
113             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
114         </tr>
115         <tr>
116             <td><input type="checkbox" name="mail"/></td>
117             <td>李四</td>
118             <td>1oaoisasja@mail.com</td>
119             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
120         </tr>
121         <tr>
122             <td><input type="checkbox" name="mail"/></td>
123             <td>王五</td>
124             <td>1oaoisasja@mail.com</td>
125             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
126         </tr>
127         <tr>
128             <td><input type="checkbox" name="mail"/></td>
129             <td>小明</td>
130             <td>1oaoisasja@mail.com</td>
131             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
132         </tr>
133         <tr>
134             <td><input type="checkbox" name="mail"/></td>
135             <td>杰克</td>
136             <td>1oaoisasja@mail.com</td>
137             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
138         </tr><tr>
139             <td><input type="checkbox" name="mail"/></td>
140             <td>不一样</td>
141             <td>1oaoisasja@mail.com</td>
142             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
143         </tr><tr>
144             <td><input type="checkbox" name="mail"/></td>
145             <td>王尼玛</td>
146             <td>1oaoisasja@mail.com</td>
147             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
148         </tr><tr>
149             <td><input type="checkbox" name="mail"/></td>
150             <td>全蛋</td>
151             <td>1oaoisasja@mail.com</td>
152             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
153         </tr><tr>
154             <td><input type="checkbox" name="mail"/></td>
155             <td>胡八一</td>
156             <td>1oaoisasja@mail.com</td>
157             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
158         </tr><tr>
159             <td><input type="checkbox" name="mail"/></td>
160             <td>匿名</td>
161             <td>1oaoisasja@mail.com</td>
162             <td>附属信息:wobuxinnihuiduwoxieleshenme</td>
163         </tr>
164         <tr>
165             <td><input type="checkbox" name="all" onclick="checkAll(this)"/>全选</td>
166             <td><input type="button" value="全不选" onclick="checkAllByBut(0)"/></td>
167             <td><input type="button" value="反选" onclick="checkAllByBut(3)"/></td>
168             <td><input type="button" value="删除所选邮件" onclick="delMails()"/></td>
169         </tr>
170     </table>
171 </body>
172 </html>
View Code

练习七:性格测试

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>性格测试</title>
 6 <style type="text/css">
 7     #no1ul{
 8         list-style:none;
 9         margin:0px;
10         padding:0px;
11     }
12     .close{
13         display:none;
14     }
15     .show{
16         color:#990000;
17     }
18 </style>
19 <script type="text/javascript">
20     function showTestResult(){
21         var radioNodes = document.getElementsByName("answer");
22         var resultNodes = document.getElementsByName("result");
23         //健壮性判断
24         var flag = false;
25         for(var x=0;x<radioNodes.length;x++){
26             if(radioNodes[x].checked){
27                 flag = true;
28                 showOne(resultNodes[x]);
29                 break;
30             }
31         }
32         if(!flag){
33             showOne(resultNodes[4]);
34         }
35     }
36     //我们希望只显示一个测试结果
37     function showOne(node){
38         var resultNodes = document.getElementsByName("result");
39         for(var x=0;x<resultNodes.length;x++){
40             //先全部close
41             resultNodes[x].className = "close";
42         }
43         //再显示这个节点
44         node.className = "show";
45     }
46 </script>
47 </head>
48 <body>
49     <h2>性格测试</h2>
50     <div>
51         <h3>问题</h3>
52         <span>每天下班回家一进门,你会怎样脱掉鞋子?</span>
53         <ul id="no1ul">
54              <li><input type="radio" name="answer" value="1"/>A、很随意的脱下鞋子,不在乎如何摆放。</li>
55             <li><input type="radio" name="answer" value="2"/>B、脱下鞋后,把鞋尖朝向门外的方向整齐排好。</li> 
56             <li><input type="radio" name="answer" value="3"/>C、脱下鞋后,把鞋尖朝屋内的方向整齐排好。</li>
57             <li><input type="radio" name="answer" value="4"/>D、不自己脱鞋,而是由同住在一起的人帮你脱下鞋子。</li>
58         </ul>
59     </div>
60     <div>
61         <input type="button" value="查看测试结果" onclick="showTestResult()"/>
62         <hr/>
63         <div id="a" name="result" class="close">
64         A:这样的人,比较喜欢自由,认为生活舒适即可,不在意细节,完全不考虑社会体制和规则的类型,以追求自我欲望为中心。
65         较冲动,喜欢自由奔放的生活方式。比较自我的人,这种人是为了追求欲望而行动的类型,仍然持续幼儿时期的性格。
66         如果往好的方向发展,当然很好;但是,如果往坏的方向发展,结果会很令人惊叹。
67         </div>
68         <div id="b" name="result" class="close">
69         B:这样的人很能吃苦,用自己的辛勤来享受生活。凡事都要准备得万全,是追求完美的人。容易在社会上树敌很多,对于同事也毫不放松。
70         他们会压抑感情,喜怒不形于色,遵守社会规范而行动。但是,这种人的心里面防卫防备很严,即使认为是为了社会公益而做的事情,也会引起很多的误解。
71         你的道德心和伦理感相当强烈,建议最好不要给自己过多的负担以免吃不消。
72         </div>
73         <div id="c" name="result" class="close">
74         C:这样的人有自己的思考方式,有自己的做事风格,会适当地考虑方式方法,是办事周到的人。这样的人骄傲,但是又适度,所以会给人以成熟自信的感觉。
75         </div>
76         <div id="d" name="result" class="close">
77         D:这样脱鞋方式的人,不用多说,一定是比较任性的人,与其说是任性,倒不如说是被完全惯坏了,因为周围的人都宠她,她要做的事情,都会由别人帮她做的很好,
78         不是说她自己没由能力,是因为她的依赖性很强,所以这样的人必须注意与周围环境的协调,否则终有一天吃大亏。
79         </div>
80         <div id="e" name="result" class="close">
81         E:你很皮!
82         </div>
83     </div>
84 </body>
85 </html>
View Code

练习八:下拉菜单

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5 <title>下拉菜单</title>
  6     <style type="text/css">
  7         .color{
  8             width:50px;
  9             height:50px;
 10             background-color:#993300;
 11             float:left;
 12             margin-bottom:20px;
 13         }
 14         div ul{
 15             margin:0px;
 16             padding:0px;
 17             margin-top:20px;
 18         }
 19         div ul li{
 20             list-style:none;
 21             clear:left;
 22         }
 23         #changeColor{
 24             margin-top:20px;
 25         }
 26     </style>
 27     <script type="text/javascript">
 28         //使用颜色块设置颜色
 29         function setColor(node){
 30             var textNode = document.getElementById("text");
 31             textNode.style.color = node.style.backgroundColor;
 32         }
 33         
 34         //使用下拉框改变颜色
 35         function changeColor(){
 36             //获取下拉框
 37             var selNode = document.getElementById("changeColor");
 38             //下拉框选项
 39             var optionsNode = selNode.options;
 40             var textNode = document.getElementById("text");
 41             
 42             textNode.style.color = optionsNode[optionsNode.selectedIndex].style.color;
 43         }
 44     </script>
 45     <script>
 46         //下拉框2
 47         function selectCity(){
 48             //获取要用到的对象
 49             var selproNode = document.getElementById("selPro");
 50             var selcityNode = document.getElementById("selCity"); 
 51             var optionsNode = selcityNode.options;
 52             var index = selproNode.selectedIndex;
 53             //设置可选城市
 54             /*方式一:
 55             var arr1 = {"beijing":['海淀区','朝阳区','东城区','西城区']};
 56             var arr2 = {"hebei":['石家庄','邯郸','保定','秦皇岛']};
 57             var arr3 = {"shandong":['津南','青岛','烟台','日照']};
 58             var arr4 = {"henan":['郑州','洛阳','开封','平顶山']};
 59             */
 60             var arr0 = ["选择城市"]; 
 61             var arr1 = ['海淀区','朝阳区','东城区','西城区'];
 62             var arr2 = ['石家庄','邯郸','保定','秦皇岛'];
 63             var arr3 = ['津南','青岛','烟台','日照'];
 64             var arr4 = ['郑州','洛阳','开封','平顶山'];
 65             var arr = [arr0,arr1,arr2,arr3,arr4];
 66             //选择省市后添加对应城市
 67             //注意:在添加前应该清空里面的内容!!!
 68             var cityArr = arr[index];
 69             for(var i=0;i<optionsNode.length;i++){
 70                 optionsNode[i].parentNode.removeChild(optionsNode[i]);
 71                 i--;//重要
 72             }
 73             for(var x=0;x<cityArr.length;x++){
 74                 var opt = document.createElement("option");
 75                 var str = cityArr[x];
 76                 opt.innerHTML = str;
 77                 selcityNode.appendChild(opt);
 78             }
 79         }
 80     </script>
 81 </head>
 82 <body>
 83     <h2>下拉框1</h2>
 84     <div class="color" style="background-color:#FF0000" onclick="setColor(this)" id="col1"></div>
 85     <div class="color" style="background-color:#00FF00" onclick="setColor(this)" id="col2"></div>
 86     <div class="color" style="background-color:#0000FF" onclick="setColor(this)" id="col3"></div>
 87     <div id="text">
 88         <ul>
 89             <li>你见,或者不见我,我就在那里,不悲不喜;</li>
 90             <li>你念,或者不念我,情就在那里,不来不去;</li>
 91             <li>你爱,或者不爱我,爱就在那里,不增不减;</li>
 92             <li>你跟,或者不跟我,我的手就在你手里,不舍不弃;</li>
 93             <li>来我的怀里,或者,让我住进你的心里</li>
 94             <li>默然 相爱 寂静 欢喜</li>
 95         </ul>
 96     </div>
 97     <select id="changeColor" onchange="changeColor()">
 98         <option value="balck">选择颜色</option>
 99         <option style="color:#FF0000">红色</option>
100         <option style="color:#00FF00">绿色</option>
101         <option style="color:#0000FF">蓝色</option>
102     </select>
103     <hr/>
104     
105     <h2>下拉框2</h2>
106     <select id="selPro" onchange="selectCity()">
107         <option value="sel">选择省市</option>
108         <option value="beijing">北京</option>
109         <option value="hebei">河北</option>
110         <option value="shandong">山东</option>
111         <option value="henan">河南</option>
112     </select>
113     <select id="selCity">
114         <option>选择城市</option>
115     </select>
116 </body>
117 </html>
View Code

练习九:添加&删除附件 

 1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
 2 <html xmlns="http://www.w3.org/1999/xhtml">
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
 5 <title>添加&删除附件</title>
 6     <style type="text/css">
 7         table a:link,table a:visited{
 8             color:#0000FF;
 9             font-family:"Times New Roman", Times, serif;
10             text-decoration:none;
11         }
12         table a:hover{
13             color:#CCCC00;
14         }
15     </style>
16     <script type="text/javascript">
17         //添加附件
18         function addFile(){
19             var tabNode = document.getElementById("myTab");
20             var rowNode = tabNode.insertRow();
21             //插入行
22             var celFileNode = rowNode.insertCell();
23             var celbuttNode = rowNode.insertCell();
24             celFileNode.innerHTML = "<input type='file'/>";
25             celbuttNode.innerHTML = "<a href='javascript:void(0)' onclick='delFile(this)'>删除</a>";
26         }
27         //删除附件
28         function delFile(node){
29             var rowNode = node.parentNode.parentNode;
30             rowNode.parentNode.removeChild(rowNode);
31         }
32     </script>
33 </head>
34 <body>
35     <table id="myTab">
36         <tr>
37             <td><a href="javascript:void(0)" onclick="addFile()">添加附件</a></td>
38         </tr>
39         <tr>
40             <td><hr/></td>
41         </tr>
42     </table>
43 </body>
44 </html>
View Code

联系十:表单检验

  1 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
  2 <html xmlns="http://www.w3.org/1999/xhtml">
  3 <head>
  4 <meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
  5 <title>表单校验</title>
  6     <style type="text/css">
  7         table{
  8             border:#006666 2px solid;
  9             width:300px;
 10             height:300px;
 11             text-align:center;
 12         }
 13     </style>
 14     <script type="text/javascript">
 15         //用户名提示
 16         function usermes(){
 17             var userflag =false;
 18             var userNode = document.getElementById("username");
 19             var name = userNode.value;
 20             //定义正则表达式规则:有两种语法方法
 21             var reg = new RegExp("^[a-z].{1,5}$","i");
 22             //var reg = /^[a-z]{4}$/;
 23             var usermesNode = document.getElementById("usermes");
 24             //判断输入是否符合规则:
 25             if(reg.test(name)){
 26                 usermesNode.innerHTML = "用户名可用".fontcolor("green");
 27                 flag = true;
 28             }    
 29             else{
 30                 usermesNode.innerHTML = "用户名必须以字母开头且长度在2-6之间".fontcolor("red");
 31                 flag = false;
 32             }
 33             return flag;
 34         }
 35         //密码提示
 36         function pswmes1(){
 37             var psw1flag =false;
 38             var pswNode = document.getElementById("psw1");
 39             var name = pswNode.value;
 40             //定义正则表达式规则:有两种语法方法
 41             var reg = new RegExp("^.{2,10}$","i");
 42             //var reg = /^[a-z]{4}$/;
 43             var pswmesNode = document.getElementById("pswmes1");
 44             //判断输入是否符合规则:
 45             if(reg.test(name)){
 46                 pswmesNode.innerHTML = "密码可用".fontcolor("green");
 47                 psw1flag = true;
 48             }
 49             else if(name==""){
 50                 pswmesNode.innerHTML = "密码不能为空".fontcolor("red");
 51                 psw1flag = false;
 52             }
 53             else{
 54                 pswmesNode.innerHTML = "密码长度必须为:2~10".fontcolor("red");
 55                 psw1flag = false;
 56             }
 57             return psw1flag;
 58         }
 59         function pswmes2(){
 60             var psw2flag =false;
 61             var psw1Node = document.getElementById("psw1");
 62             var name1 = psw1Node.value;
 63             var psw2Node = document.getElementById("psw2");
 64             var name2 = psw2Node.value;
 65             
 66             var pswmesNode = document.getElementById("pswmes2");
 67             //判断输入是否符合规则:
 68             if(name1==name2){
 69                 if(name2==""){
 70                     pswmesNode.innerHTML = "密码不能为空".fontcolor("red");
 71                     psw2flag = false;
 72                 }
 73                 else{
 74                     pswmesNode.innerHTML = "输入一致".fontcolor("green");
 75                     psw2flag = true;
 76                 }    
 77             }
 78             else{
 79                 pswmesNode.innerHTML = "两次密码输入不一致".fontcolor("red");
 80                 psw2flag = false;
 81             }
 82             return psw2flag;
 83         }
 84         //提交校验
 85         function checkForm(){
 86             var formflag;
 87             var psw1Node = document.getElementById("submes");
 88             if(usermes() && psw1mes() && psw2mes()){
 89                 alert("提交成功");
 90                 formflag = true;
 91             }
 92             else{
 93                 alert("输入有误,无法提交");
 94                 formflag = false;
 95             }
 96             return formflag;
 97         }
 98     </script>
 99 </head>
100 <body>
101     <h2>新用户注册</h2>
102     <form onsubmit="return checkForm()">
103         <table id="userTab">
104             <tr>
105                 <td>用户名称:<input type="text" id ="username" onblur="usermes()"/></td>
106             </tr>
107             <tr>
108                 <td id="usermes"></td>
109             </tr>
110             <tr>
111                 <td>&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;码:<input type="password" id ="psw1" onblur="pswmes1()"/></td>
112             </tr>
113             <tr>
114                 <td id="pswmes1"></td>
115             </tr>
116             <tr>
117                 <td>确认密码:<input type="password" id ="psw2" onblur="pswmes2()"/></td>
118             </tr>
119             <tr>
120                 <td id="pswmes2"></td>
121             </tr>
122         </table>
123         <input type="submit" value="确认注册" style="font-size:16px"/>
124     </form>
125 </body>
126 </html>
View Code
posted @ 2017-11-03 12:09  风之之  阅读(2812)  评论(0编辑  收藏  举报