实现可以编辑的表格

直接上代码:

<!DOCTYPE html>
<html>
<head lang="en">
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>实现可以编辑的表格 </title>
    <style>
        td,tr{
            border: 1px solid skyblue;
        }
    </style>
</head>
<dody>
    <table>
        <tbody>
        <tr>
            <td>123123132</td>
            <td>4465465465456</td>
        </tr>
        </tbody>
    </table>
</dody>
<script src="js/jquery.min.js"></script>
<script>
    //让所有td拥有一个点击事件
    $(document).ready(function(){
        var tds = $("td");
        tds.click(tdclick);
    });

    //td被点击的事件
    function tdclick(){
        //      var clickfunction = this; //将当前的方法进行保存
        //0.保存当前的td节点
        var td = $(this);
        //1.取出当前td中的文本内容保存起来
        var text = $(this).text();
        //2.清空td里面的内容
        td.html('');  //也可以用td.empty();
        //3.建立一个文本框,也就是input的元素及诶单
        var input = $("<input>");
        //4.设置文本框的值是保存起来的文本内容
        input.attr("value",text);
        //5.将文本框加入到td        //4.5让文本框可以响应键盘按下的事件,主要用于处理回车确认
        input.keyup(function(event){
            //0.获取当前用户按下的键值
            //解决不同浏览器获取事件对象的差异
            var myEvent = event || window.event;
            var kcode = myEvent.keyCode;
            //1.判断是否是回车按下
            if(kcode ==13){
                var  inputnode = $(this);
                //2.保存当前文本框的内容
                var inputtext = inputnode.val();
                //3.清空td里面的内容
                var tdNode = inputnode.parent();
                //4.将保存的文本个框的内容填充到td                tdNode.html(inputtext);
                //5.td重新拥有点击事件
                tdNode.click(tdclick);
            }
        });
        td.append(input);   //也可以用input.appendTo(td)
        //需要清除td上的点击事件
        td.unbind("click");
    }
</script>
</html>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值