JQuery实战总结一 可编辑的表格

来源:互联网 发布:穿越还珠之美女知画 编辑:程序博客网 时间:2024/05/21 22:22

这里要先引入jquery.js文件,和自己编写的js文件EditTable.js文件、CSS样式文件,就能达到我们想要的效果噢

 

[html] view plain copy
 print?
  1. <span style="font-size:18px;"><!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">  
  2. <html>  
  3.     <head>  
  4.         <title>JQuery实例2,可以编辑的表格</title>  
  5.         <meta http-equiv="Content-Type" content="text/html; charset=gb2312">  
  6.         <link type="text/css" rel="stylesheet" href="css/editTable.css" />  
  7.         <script type="text/javascript" src="js/jquery.js"></script>  
  8.         <script type="text/javascript" src="js/editTable.js"></script>  
  9.     </head>  
  10.     <body>  
  11.     <table>  
  12.         <thead>  
  13.                <tr>  
  14.                      <th colspan="2">鼠标单击表格项就可以编辑</th>  
  15.                </tr>  
  16.                  
  17.         </thead>  
  18.         <tbody>  
  19.            <tr>  
  20.                <th>学号</th>  
  21.                <th>姓名</th>  
  22.            </tr>  
  23.            <tr>  
  24.              <td>A0001</td>  
  25.              <td>李社河</td>  
  26.            </tr>  
  27.             <tr>  
  28.              <td>B0002</td>  
  29.              <td>李四</td>  
  30.            </tr>  
  31.             <tr>  
  32.              <td>C0003</td>  
  33.              <td>李龙</td>  
  34.            </tr>  
  35.             <tr>  
  36.              <td>D0004</td>  
  37.              <td>赵六</td>  
  38.            </tr>  
  39.         <tbody>  
  40.     </table>  
  41. </body>  
  42. </html>  
  43.   
  44. </span>  


 

CSS:控制表格中的样式

 

[css] view plain copy
 print?
  1. <span style="font-size:18px;">table {  
  2.     border:1px solid black;  
  3.     /*修正单元格中的不能合并的问题*/  
  4.       
  5.     border-collapse:collapse;  
  6.     width:400px;  
  7. }  
  8. table td{  
  9. border:1px solid black;  
  10. width:50%;  
  11. }  
  12. table th{  
  13. border:1px solid black;  
  14. width:50%;  
  15. }  
  16. tbody th{  
  17.  background-color:#A3BAE9;  
  18. }</span>  


 

editTable.js,真正的实现可修改的部分的内容区域

 

[javascript] view plain copy
 print?
  1. <span style="font-size:18px;">//需要通过Javascript来解决内容部分基偶行的背景颜色不同  
  2. //$(document).ready(function(){  
  3. //  
  4.   
  5. //});  
  6. //简化的ready写法  
  7. $(function(){  
  8. //找到表格的内容区域中除了第一个tr以外的所有的奇数行  
  9.         //使用even是为了把通过tbody tr返回的所有tr元素中,  
  10.         //在数组里面下标是偶数的元素返回,因为这些元素,实际上才是我们期望的tbody里面的技术行  
  11.                 $("tbody tr:even").css("background-color","#ECE9D8");  
  12.   
  13.         //需要找到所有的学号单元格  
  14. //$("tbody td:even").css("background-color","red")        
  15.             var numId = $("tbody td:even");   
  16.             //给这些单元格注册鼠标点击事件  
  17.             numId.click(function(){  
  18.                 //找到当前的鼠标点击td,this对应的就是响应了click的那个td  
  19.                     var tdObj = $(this);  
  20.                     if (tdObj.children("input").length >0){  
  21.                     //当前的td中input,不执行click处理  
  22.                     return false;  
  23.                     }  
  24.                       
  25.                     var text = tdObj.html();  
  26.                      //清空td中的内容  
  27.                     tdObj.html("");  
  28.                       
  29.                     //创建一个文本框  
  30.                     //去掉 文本框的边框  
  31.                     //设置文本框的文字字体大小是16px  
  32.                     //是文本框的宽度和td的宽度相同  
  33.                     //设置文本框的背景色  
  34.                     //需要将当前的td中的内容放到文本框中  
  35.                     //将文本框插入到td中  
  36.                     var inputObj = $("<input type='text'>").css("border-width","0")  
  37.                     .css("font-size","16px").width(tdObj.width())  
  38.                     .css("background-color",tdObj.css("background-color"))  
  39.                     .val(text).appendTo(tdObj);  
  40.                     //文本框插入之后被选中  
  41.                     inputObj.trigger("focus").trigger("select");  
  42.                     inputObj.click(function(){  
  43.                     return false;  
  44.                     });  
  45.                     //处理文本框上回车和esc按键的操作  
  46.                     inputObj.keyup(function(event){  
  47.                     //获取当前按下键盘的键值  
  48.                     var keycode = event.which;  
  49.                       
  50.                     //处理回车的情况  
  51.                     if (keycode == 13){  
  52.                     //获取当前文本框的内容  
  53.                     var inputtext = $(this).val();  
  54.                     //将td的内容修改成文本框中的内容  
  55.                     tdObj.html(inputtext);  
  56.                     }  
  57.                       
  58.                     //处理esc的情况  
  59.                       
  60.                     if (keycode == 27){  
  61.                     //将td中的内容还原成text  
  62.                     tdObj.html(text);  
  63.                     }  
  64.                     });  
  65.                 });  
  66.               
  67. });</span>  

 

运行前:


 

 

运行后的效果:

 

 

总结知识点:

1.table中可以包含thead和tbody

2.表头的内容可以放在th中

3.table{}这种写法称作变迁选择器,可以对整个页面所有table产生影响

4.table td{}这种写法表示的是table中包含的所有td

5.可以通过border-collapse:collapse这种方式来使表格中的单元格的边框合并。

6.当th上由背景色时,这个th属于的tr上定义的背景色会失效

7.$(function{})是$(document).ready(function(){})的简化写法

8.$("tbody tr")可以返回tbody中的所有tr节点

9.$("tbody tr:even")可以返回tbody中所有索引值是偶数的tr节点(注意这个偶数是指返回

数组的偶数)

10.css方法可以用于设定或获取节点的css属性,参数名是css的属性名

11.JQuery的对象内容包含着选择器对应的DOM节点,以数组形式保存,

12.get方法可以获得JQuery对象那个中包含的某一个DOM节点

13.function中的this代表执行这个function的对象

14.$()方法的参数是一个DOM对象时,这个方法相当于把DOM对象转换成JQuery对

象。

15.children方法可以获得某个节点的子节点,可以指定参数来限制子节点的内容

16.如果选择器返回的JQuery对象中包含多个DOM节点,在这个对象上注册类似click

这样的事件时,所有DOM节点都会用于事件

17.html方法可以设置或获取节点的HTML内容

18.val方法可以获取或设置节点的value值

19.$()方法的参数如果是一段正确的HTML文本,则可以创建一个DOM节点,并包装

成JQuery对象。如$("<input type='text'/>")

20.JQuery大部分方法都会返回执行这个方法的JQuery对象,因此可以采用链式方法的写法来编写给予JQuery的代码。注:Java的StringBuffer也有

21.appendTo方法可以将一个节点追加到另一个节点所有子节点的后面

22.阻止事件传递可以让当前节点的事件返回false
如:可以应用到对某些事件的不响应。function(){return false;}

23.trigger方法可以出发某个JavaScript的事件发生。

24.width方法可以设置或获取某个节点的宽度。

25.JQuery中某个事件方法的参数function上可以定义一个event的参数,JQuery会屏蔽浏览器的event差异,传给我们一个可用的event对象。

26.JQuery的event对象上有一个which的属性可以获取键盘按键的键值
如:inputobj.keyup(function(event)){ var keycode = event.which;}

27.13表示回车键,27表示ESC键

0 0
原创粉丝点击