zoukankan      html  css  js  c++  java
  • JQuery实现可直接编辑的表格

    本文实例讲述了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){
      //td中已经有了input,则不需要响应点击事件
      if($(this).children("input").length > 0)
       return false;
      var tdObj = $(this);
      var preText = tdObj.html();
      //得到当前文本内容
      var inputObj = $("<input type='text' />");
      //创建一个文本框元素
      tdObj.html(""); //清空td中的所有元素
      inputObj
       .width(tdObj.width())
       //设置文本框宽度与td相同
       .height(tdObj.height())
       .css({border:"0px",fontSize:"17px",font:"宋体"})
       .val(preText)
       .appendTo(tdObj)
       //把创建的文本框插入到tdObj子节点的最后
       .trigger("focus")
       //用trigger方法触发事件
       .trigger("select");
      inputObj.keyup(function(event){
       if(13 == event.which)
       //用户按下回车
       {
        var text = $(this).val();
        tdObj.html(text);
       }
       else if(27 == event.which)
       //ESC键
       {
        tdObj.html(preText);
       }
      });
      //已进入编辑状态后,不再处理click事件
      inputObj.click(function(){
       return false;
      });
     });
    });
  • 相关阅读:
    http://www.bugku.com:Bugku——SQL注入1(http://103.238.227.13:10087/)
    [笔记]一道C语言面试题:大整数乘法
    [笔记] Access Control Lists (ACL) 学习笔记汇总
    [笔记]如何将传统的回调函数转换为C#5.0支持的await格式
    6.链接与导航
    9章 下拉菜单
    11章圆角框 本章很重要 经常用到
    原来链接与导航
    7竖直排列的导航菜单
    8.水平导航菜单
  • 原文地址:https://www.cnblogs.com/sjqq/p/6392001.html
Copyright © 2011-2022 走看看