【JQuery实战视频教程】
功能:创建一个表格,用户单击某个单元格后,可以直接修改单元格文本。
在编辑状态下,用户可按回车键确认修改,按ESC键撤销修改。
效果:
思路:
当用户点击某个单元格后,立即向该单元格内插入一个文本框,将它的宽、高都设置成与单元格相的数值。用户确认输入后,清空该单元格内的所有HTML代码,然后把内容设置为用户刚刚输入的文本。
HTML代码:
- <table align="center">
- <tr>
- <td>学号</td>
- <td>姓名</td>
- </tr>
- <tr>
- <td>001</td>
- <td>dog</td>
- </tr>
- <tr>
- <td>002</td>
- <td>cat</td>
- </tr>
- <tr>
- <td>003</td>
- <td>pig</td>
- </tr>
- </table>
JavaScript代码:
- $(function(){
- $("td").click(function(event){
-
- if($(this).children("input").length > 0)
- return false;
-
- var tdObj = $(this);
- var preText = tdObj.html();
- var inputObj = $("<input type='text' />");
-
- tdObj.html("");
- inputObj
- .width(tdObj.width())
- .height(tdObj.height())
- .css({border:"0px",fontSize:"17px",font:"宋体"})
- .val(preText)
- .appendTo(tdObj)
- .trigger("focus")
- .trigger("select");
-
- inputObj.keyup(function(event){
- if(13 == event.which)
- {
- var text = $(this).val();
- tdObj.html(text);
- }
- else if(27 == event.which)
- {
- tdObj.html(preText);
- }
- });
-
-
- inputObj.click(function(){
- return false;
- });
- });
- });