码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 【HTML】操作表格


    元素是HTML中最复杂的结构之一。要想创建表格,一般都必须涉及表示表格行、单元格、表头等方面的标签。由于涉及的标签多,因而使用核心DOM方法创建和修改表格往往都免不了要编写大量的代码。假设我们要使用DOM来创建下面的HTML表格。

        <tbody>
           
               
               
           
           
               
               
           
       
    Cell 1,1Cell 2,1
    Cell 1,2Cell 2,2

    要使用核心DOM方法创建这些元素,得需要像下面这么多的代码:
    //创建table
    var table = document.createElement("table");
    table.border = 1;
    table.width = "100%";

    //创建tbody
    var tbody = document.createElement("tbody");
    table.appendChild(tbody);

    //创建第一行
    var row1 = document.createElement("tr");
    tbody.appendChild(row1);
    var cell1_1 = document.createElement("td");
    cell1_1.appendChild(document.createTextNode("Cell 1,1"));
    row1.appendChild(cell1_1);
    var cell2_1 = document.createElement("td");
    cell2_1.appendChild(document.createTextNode("Cell 2,1"));
    row1.appendChild(cell2_1);

    //创建第二行
    var row2 = document.createElement("tr");
    tbody.appendChild(row2);
    var cell1_2 = document.createElement("td");
    cell1_2.appendChild(document.createTextNode("Cell 1,2"));
    row2.appendChild(cell1_2);
    var cell2_2= document.createElement("td");
    cell2_2.appendChild(document.createTextNode("Cell 2,2"));
    row2.appendChild(cell2_2);

    //将表格添加到文档主体中
    document.body.appendChild(table);

    显然,DOM代码很长,还有点不太好懂。为了方便构建表格,HTML DOM还为

    、和元素添加了一些属性和方法。
    为元素添加的属性和方法如下。

    caption:保存着对

    元素的HTMLCollection。
    tFoot:保存着对元素(如果有)的指针。
    tHead:保存着对元素(如果有)的指针。
    rows:是一个表格中所有行的HTMLCollection。

    createTHead():创建

    元素,将其放到表格中,返回引用。
    createTFoot():创建元素,将其放到表格中,返回引用。
    createCaption():创建元素。
    deleteTFoot():删除元素。
    deleteCaption():删除元素添加的属性和方法如下。
    rows:保存着元素中行的HTMLCollection。
    deleteRow(pos):删除指定位置的行。

    insertRow(pos):向rows集合中的指定位置插入一行,返回对新插入行的引用。
    为

    元素添加的属性和方法如下。
    cells:保存着元素中单元格的HTMLCollection。
    deleteCell(pos):删除指定位置的单元格。
    insertCell(pos):向cells集合中的指定位置插入一个单元格,返回对新插入单元格的引用。
    使用这些属性和方法,可以极大地减少创建表格所需的代码数量。例如,使用这些属性和方法可以将前面的代码重写如下(加阴影的部分是重写后的代码)。
    //创建table
    var table = document.createElement("table");
    table.border = 1;
    table.width = "100%";

    //创建tbody
    var tbody = document.createElement("tbody");
    table.appendChild(tbody);

    //创建第一行tbody.insertRow(0);tbody.rows[0].insertCell(0);tbody.rows[0].cells[0].appendChild(document.createTextNode("Cell 1,1"));tbody.rows[0].insertCell(1);tbody.rows[0].cells[1].appendChild(document.createTextNode("Cell 2,1"));//创建第二行tbody.insertRow(1);tbody.rows[1].insertCell(0);tbody.rows[1].cells[0].appendChild(document.createTextNode("Cell 1,2"));tbody.rows[1].insertCell(1);tbody.rows[1].cells[1].appendChild(document.createTextNode("Cell 2,2"));

    //将表格添加到文档主体中
    document.body.appendChild(table);

    在这次的代码中,创建

    元素(如果有)的指针。
    tBodies:是一个
    元素,将其放到表格中,返回引用。
    deleteTHead():删除
    元素。
    deleteRow(_pos_):删除指定位置的行。
    insertRow(_pos_):向rows集合中的指定位置插入一行。
    为
    和的代码没有变化。不同的是创建两行的部分,其中使用了HTML DOM定义的表格属性和方法。在创建第一行时,通过元素调用了insertRow()方法,传入了参数0——表示应该将插入的行放在什么位置上。执行这一行代码后,就会自动创建一行并将其插入到元素的位置0上,因此就可以马上通过tbody.rows[0]来引用新插入的行。
    创建单元格的方式也十分相似,即通过元素调用insertCell()方法并传入放置单元格的位置。然后,就可以通过tbody.rows[0].cells[0]来引用新插入的单元格,因为新创建的单元格被插入到了这一行的位置0上。
    总之,使用这些属性和方法创建表格的逻辑性更强,也更容易看懂,尽管技术上这两套代码都是正确的。

    想要了解更多Java基础知识,可以点击评论区链接和小编一起学习java吧,此视频教程为初学者而著,零基础入门篇!给同学们带来全新的Java300集课程啦!java零基础小白自学Java必备优质教程_手把手图解学习Java,让学习成为一种享受_哔哩哔哩_bilibili

  • 相关阅读:
    N-Gram模型介绍
    入坑机器学习:三,非监督学习
    数字化时代,低代码是企业的未来共识吗?
    Hugging News #0626: 音频课程更新、在线体验 baichuan-7B 模型、ChatGLM2-6B 重磅发
    【Redis】为什么要学 Redis
    1.FreeRTOS简介及多任务点灯
    [附源码]java毕业设计基于的疫苗预约系统
    关于爬虫!看这一篇就够了!
    QCN6274 vs QCA9880: Comparison of SOC and wireless communication chips
    机器学习文献|基于循环细胞因子特征,通过机器学习算法预测NSCLC免疫治疗结局
  • 原文地址:https://blog.csdn.net/zf888999666/article/details/127994806
    • 最新文章
    • 攻防演习之三天拿下官网站群
      数据安全治理学习——前期安全规划和安全管理体系建设
      企业安全 | 企业内一次钓鱼演练准备过程
      内网渗透测试 | Kerberos协议及其部分攻击手法
      0day的产生 | 不懂代码的"代码审计"
      安装scrcpy-client模块av模块异常,环境问题解决方案
      leetcode hot100【LeetCode 279. 完全平方数】java实现
      OpenWrt下安装Mosquitto
      AnatoMask论文汇总
      【AI日记】24.11.01 LangChain、openai api和github copilot
    • 热门文章
    • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
      奉劝各位学弟学妹们,该打造你的技术影响力了!
      五年了,我在 CSDN 的两个一百万。
      Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
      面试官都震惊,你这网络基础可以啊!
      你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
      心情不好的时候,用 Python 画棵樱花树送给自己吧
      通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
      13 万字 C 语言从入门到精通保姆级教程2021 年版
      10行代码集2000张美女图,Python爬虫120例,再上征途
    Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
    正则表达式工具 cron表达式工具 密码生成工具

    京公网安备 11010502049817号