• js 实现表格的可编辑状态


    <table border="0" style="200px;margin:30px auto">
    <tr><td>1</td><td>2</td><td><!-- <input type="button" value="编辑"> --><img src="edit.png" class="edit"></td></tr>
    <tr><td>1</td><td>2</td><td><!-- <input type="button" value="编辑"> --><img src="edit.png" class="edit"></td></tr>
    <tr><td>1</td><td>2</td><td><!-- <input type="button" value="编辑"> --><img src="edit.png" class="edit"></td></tr>
    <tr><td>1</td><td>2</td><td><!-- <input type="button" value="编辑"> --><img src="edit.png" class="edit"></td></tr>
    <tr><td>1</td><td>2</td><td><!-- <input type="button" value="编辑"> --><img src="edit.png" class="edit"></td></tr>
    </table>
    <script src="jquery-1.11.3.js"></script>
    <script type="text/javascript">
    $(function(){
    $(".edit").click(function() {
    //str = $(this).val()=="编辑"?"确定":"编辑";
    //$(this).val(str); // 按钮被点击后,在“编辑”和“确定”之间切换
    var str = $(this).attr("src")=="edit.png"?"phone.png":"edit.png";
    $(this).attr("src",str);
    $(this).parent().siblings("td").each(function() { // 获取当前行的其他单元格
    var obj_text = $(this).find("input:text"); // 判断单元格下是否有文本框
    if(!obj_text.length) // 如果没有文本框,则添加文本框使之可以编辑
    $(this).html("<input type='text' value='"+$(this).text()+"'>");
    else // 如果已经存在文本框,则将其显示为文本框修改的值
    $(this).html(obj_text.val());
    });
    });
    });
    </script>
     说明:1、在table的某个单元格点击中,先取出该单元格的值,再将该值赋给一个input text,并将这个input text动态添加到这个单元格中,代码可以写成:
    var tdvalue=$(this).val();
    $(this).html("<input id='tempinput' type='text' value='"+tdvalue+"'/>");
    2、当单元格失去焦点时,将文本框的值回填给单元格,代码写成:
    $(this).html($("tempinput").val());
    3、实际写代码时还要考虑临时加入的文本框的宽度要与单元格一致等内容。

    简易效果图: 

  • 相关阅读:
    mysql 远程登录修改配置
    scrapy--分布式爬虫
    win10---cmd终端下连接ubantu--SSH SERVER服务
    将python环境打包成.txt文件
    ubantu安装python3虚拟环境
    selenium 自动化安装火狐谷歌插件
    mysql主从复制-读写分离-原理
    mysql主从复制原理
    mysql储存引擎
    mysql检查-优化-分析
  • 原文地址:https://www.cnblogs.com/poppy1314/p/6248644.html
Copyright © 2020-2023  润新知