百分百源码网-让建站变得如此简单! 登录 注册 签到领金币!

主页 | 如何升级VIP | TAG标签

当前位置: 主页>网站教程>html5教程> HTML中表格动态增加的办法
分享文章到:

HTML中表格动态增加的办法

发布时间:09/01 来源:未知 浏览: 关键词:
总结:以上就是本篇文的全部内容HTML中表格动态增加的办法,但愿能对大家的学习有所帮忙。 相关引荐:

详细代码如下所示:

<html>  
    <head><title>Table</title></head>  
    <body>  
        <table border="1">  
            <thead>  
                <tr>  
                    <td>First Name</td>  
                    <td>Last Name</td>  
                    <td> </td>  
                </tr>  
            <thead>  
            <tbody id="tb">  
                <tr id="1st">  
                    <td>张</td>  
                    <td>三</td>  
                    <td><input type="button" value="Add" onclick="add()">   
                    <input type="button" value="Del" onclick="del(this)"></td>  
                </tr>  
            </tbody>  
        </table>  
    </body>  
</html>  
<script>  
    function add() {  
        var trObj = document.createElement("tr");  
        trObj.id = new Date().getTime();  
        trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'> <input type='button' value='Del' onclick='del(this)'></td>";  
        document.getElementById("tb").appendChild(trObj);  
    }  
    function del(obj) {  
        var trId = obj.parentNode.parentNode.id;  
        var trObj = document.getElementById(trId);  
        document.getElementById("tb").removeChild(trObj);  
    }  
</script>

上面的代码中,第一在body中结构了一个table,为了利便后续的操纵,我们给table增加了thead 和 tbody 标签,thead标签标示的是表格头,tbody标签标示的是表格主体。

示例中的表格,共有三列,第一列 first name,第二列 last name,第三列为操纵列。

操纵列中,包括两个操纵,一个是给表格增加行,一个是删除当前行。增加行和删除行的操纵离别绑在两个按钮上,点击按钮时,触发响应的增加行/ 删除行 操纵。

增加行办法

function add() {  
        var trObj = document.createElement("tr");  
        trObj.id = new Date().getTime();  
        trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'> <input type='button' value='Del' onclick='del(this)'></td>";  
        document.getElementById("tb").appendChild(trObj);  
    }

第一行,创立tr元素,即创立一个表格行。

第二行,trObj.id = new Date().getTime(); 给改行增加id 属性,并给属性赋值,取当前系统的毫秒数,这个主如果删除的时候需要。

第三行,trObj.innerHTML = "<td><input name='firstName'/></td><td><input name='lastName'/></td><td><input type='button' value='Add' onclick='add()'>

<input type='button' value='Del' onclick='del(this)'></td>"; 给表格行赋值,通过innerHTMML属性,设定<tr>标签和</tr> 标签间的html代码内容,也就是要增加的行内容。

第四行,document.getElementById("tb").appendChild(trObj); 将创立好的表格行增加到表格主体中。

删除行办法

function del(obj) {  
    var trId = obj.parentNode.parentNode.id;  
    var trObj = document.getElementById(trId);  
    document.getElementById("tb").removeChild(trObj);  
}

删除办法中传递了一个参数,在增加行办法中,我们可以看到删除办法del 中传递了this参数,页面代码中的this指代的是当前的HTML元素,即this所在的<input >域。

第一行,var trId = obj.parentNode.parentNode.id; 猎取当前元素的父节点的父节点的id,即要删除的行的id 。

第二行,var trObj = document.getElementById(trId); 猎取要删除的行元素。

第三行,document.getElementById("tb").removeChild(trObj); 在表格主体中删除该行。

瑕疵

上面的代码根本实现了动态给表格增添行和删除行的功效,但是代码还有瑕疵,主要有这么两点:

1 表格在增添行前和增添行后,表格宽度发生转变

增添行前

增添行后

增添行后,表格列变宽了

2 阅读器默许翻开的页面中文显现乱码

需要 设定字符编码修改页面编码格局后才能正常显示

总结:以上就是本篇文的全部内容,但愿能对大家的学习有所帮忙。

相关引荐:

HTML中的超级链接<a>标签

html标签中lang的作用

html中标签制作表单实例

以上就是HTML中表格动态增加的办法的具体内容,更多请关注百分百源码网其它相关文章!

打赏

打赏

取消

感谢您的支持,我会继续努力的!

扫码支持
扫码打赏,你说多少就多少

打开支付宝扫一扫,即可进行扫码打赏哦

百分百源码网 建议打赏1~10元,土豪随意,感谢您的阅读!

共有151人阅读,期待你的评论!发表评论
昵称: 网址: 验证码: 点击我更换图片
最新评论

本文标签

广告赞助

能出一分力是一分吧!

订阅获得更多模板

本文标签

广告赞助

订阅获得更多模板