为什么我的 <td> 元件没有以 100vw 显示?

How come my <td> elements are not displaying at 100vw?

提问人:journeywithjavascript 提问时间:11/11/2023 最后编辑:Tim Rjourneywithjavascript 更新时间:11/11/2023 访问量:54

问:

我正在遵循 FreeCodeCamp 的响应式网页设计课程。我正在模块“通过构建资产负债表了解有关 CSS 伪选择器的更多信息”步骤 53。第一条指令是将 tbody 内部 td 元素的宽度设置为 100vw。我的期望是,当我这样做时,每个 td 的宽度应该等于视口的宽度。然而,事实并非如此。有人可以解释为什么吗?我将在下面提供源代码,尽管有很多:

span[class~="sr-only"] {
  border: 0 !important;
  clip: rect(1px, 1px, 1px, 1px) !important;
  clip-path: inset(50%) !important;
  height: 1px !important;
  width: 1px !important;
  position: absolute !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  padding: 0 !important;
  margin: -1px !important;
}

html {
  box-sizing: border-box;
}

body {
  font-family: sans-serif;
  color: #0a0a23;
}

h1 {
  max-width: 37.25rem;
  margin: 0 auto;
  padding: 1.5rem 1.25rem;
}

h1 .flex {
  display: flex;
  flex-direction: column-reverse;
  gap: 1rem;
}

h1 .flex span:first-of-type {
  font-size: 0.7em;
}

h1 .flex span:last-of-type {
  font-size: 1.2em;
}

section {
  max-width: 40rem;
  margin: 0 auto;
  border: 2px solid #d0d0d5;
}

#years {
  display: flex;
  justify-content: flex-end;
  position: sticky;
  z-index: 999;
  top: 0;
  background: #0a0a23;
  color: #fff;
  padding: 0.5rem calc(1.25rem + 2px) 0.5rem 0;
  margin: 0 -2px;
}

#years span[class] {
  font-weight: bold;
  width: 4.5rem;
  text-align: right;
}

.table-wrap {
  padding: 0 0.75rem 1.5rem 0.75rem;
}

span {
  font-weight: normal;
}

table {
  border-collapse: collapse;
  border: 0;
  width: 100%;
  position: relative;
  margin-top: 3rem;
}

table caption {
  color: #356eaf;
  font-size: 1.3em;
  font-weight: normal;
  position: absolute;
  top: -2.25rem;
  left: 0.5rem;
}

tbody td {
  width: 100vw;

}
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Balance Sheet</title>
    <link rel="stylesheet" href="./styles.css">
  </head>
  <body>
    <main>
      <section>
        <h1>
          <span class="flex">
            <span>AcmeWidgetCorp</span>
            <span>Balance Sheet</span>
          </span>
        </h1>
        <div id="years" aria-hidden="true">
          <span class="year">2019</span>
          <span class="year">2020</span>
          <span class="year">2021</span>
        </div>
        <div class="table-wrap">
          <table>
            <caption>Assets</caption>
            <thead>
              <tr>
                <td></td>
                <th><span class="sr-only year">2019</span></th>
                <th><span class="sr-only year">2020</span></th>
                <th class="current"><span class="sr-only year">2021</span></th>
              </tr>
            </thead>
            <tbody>
              <tr class="data">
                <th>Cash <span class="description">This is the cash we currently have on hand.</span></th>
                <td>$25</td>
                <td>$30</td>
                <td class="current">$28</td>
              </tr>
              <tr class="data">
                <th>Checking <span class="description">Our primary transactional account.</span></th>
                <td>$54</td>
                <td>$56</td>
                <td class="current">$53</td>
              </tr>
              <tr class="data">
                <th>Savings <span class="description">Funds set aside for emergencies.</span></th>
                <td>$500</td>
                <td>$650</td>
                <td class="current">$728</td>
              </tr>
              <tr class="total">
                <th>Total <span class="sr-only">Assets</span></th>
                <td>$579</td>
                <td>$736</td>
                <td class="current">$809</td>
              </tr>
            </tbody>
          </table>
          <table>
            <caption>Liabilities</caption>
            <thead>
              <tr>
              <td></td>
              <th><span class="sr-only">2019</span></th>
              <th><span class="sr-only">2020</span></th>
              <th><span class="sr-only">2021</span></th>
              </tr>
            </thead>
            <tbody>
              <tr class="data">
                <th>Loans <span class="description">The outstanding balance on our startup loan.</span></th>
                <td>$500</td>
                <td>$250</td>
                <td class="current">$0</td>
              </tr>
              <tr class="data">
                <th>Expenses <span class="description">Annual anticipated expenses, such as payroll.</span></th>
                <td>$200</td>
                <td>$300</td>
                <td class="current">$400</td>
              </tr>
              <tr class="data">
                <th>Credit <span class="description">The outstanding balance on our credit card.</span></th>
                <td>$50</td>
                <td>$50</td>
                <td class="current">$75</td>
              </tr>
              <tr class="total">
                <th>Total <span class="sr-only">Liabilities</span></th>
                <td>$750</td>
                <td>$600</td>
                <td class="current">$475</td>
              </tr>
            </tbody>
          </table>
          <table>
            <caption>Net Worth</caption>
            <thead>
              <tr>
              <td></td>
              <th><span class="sr-only">2019</span></th>
              <th><span class="sr-only">2020</span></th>
              <th><span class="sr-only">2021</span></th>
              </tr>
            </thead>
            <tbody>
              <tr class="total">
                <th>Total <span class="sr-only">Net Worth</span></th>
                <td>$-171</td>
                <td>$136</td>
                <td class="current">$334</td>
              </tr>
            </tbody>
          </table>
        </div>
      </section>
    </main>
  </body>
</html>

渲染:

enter image description here

在 td 上使用边框进行渲染,以更好地说明宽度(它远小于 100vw - 这应该是视口的 100%,对吧?

enter image description here

提前致谢!

、CS、 HTML-TABLE-WIDTH 视口

评论

0赞 journeywithjavascript 11/11/2023
我有一种感觉,这些元素(或围绕表格的其他因素)可能与事物有关。我不确定为什么他们会阻止 td 元素以 100vw 显示,您能解释一下吗?
0赞 journeywithjavascript 11/11/2023
在这些问题中,在 HTML 之前共享 CSS 是否是最佳做法?我之前问过一个问题,有人将 CSS 换成 HTML,我一直认为先发布 HTML 是有意义的。
0赞 Sanxofon 11/11/2023
Tim R 所做的是将代码放在一个可以在浏览器中测试的代码片段中。该代码段强制 CSS 位于顶部。
0赞 journeywithjavascript 11/11/2023
@Sanxofon哦,我明白了,谢谢。我对这个平台还是很陌生的啊哈。
0赞 Sanxofon 11/11/2023
再看一遍我的答案。我已经用解释更新了它。如果您喜欢答案,请标记为是否被接受。

答:

2赞 Sanxofon 11/11/2023 #1

一般来说,HTML 中的某些元素像 ,或者已经以更“常见”的方式设置了一些 CSS 属性。也就是说,某些属性(如 )的默认值与其他元素(例如 .<td><tr><table>width<tr><div>

在您的问题中,尽管您为 设置了值,但此元素位于其他父元素 ( 和 ) 中,这些父元素具有默认定义的属性,在本例中,它将其属性强加给其子元素。 每种类型的 HTML 元素都有其与其对应的所有 CSS 属性的默认值。width<td><tr><table>width

您可以在此处查看一长串默认值: CSS 默认值参考

试试这个:

table,tbody,tr {
  width: max-content;
}
tbody td {
  width: 100vw;
}

table,tbody,tr {
  width: max-content;
}
tbody td {
  width: 100vw;
}
          <table border=1>
            <tbody>
              <tr class="data">
                <th>Cash <span class="description">This is the cash we currently have on hand.</span></th>
                <td>$25</td>
                <td>$30</td>
                <td class="current">$28</td>
              </tr>
              <tr class="data">
                <th>Checking <span class="description">Our primary transactional account.</span></th>
                <td>$54</td>
                <td>$56</td>
                <td class="current">$53</td>
              </tr>
              <tr class="data">
                <th>Savings <span class="description">Funds set aside for emergencies.</span></th>
                <td>$500</td>
                <td>$650</td>
                <td class="current">$728</td>
              </tr>
              <tr class="total">
                <th>Total <span class="sr-only">Assets</span></th>
                <td>$579</td>
                <td>$736</td>
                <td class="current">$809</td>
              </tr>
            </tbody>
          </table>

评论

0赞 journeywithjavascript 11/11/2023
感谢您的回复!因此,这实际上将 td 的宽度设置为 100vw。但我更感兴趣的是为什么它们没有像我那样以 100vw 的宽度显示背后的解释。我的目标不是实现每 td 100vw,而是理解为什么在我的情况下它没有显示 100vw。我理解事物的方式,它应该显示每个宽度为 100vw 的 td,但它没有,所以我希望能修复我的理解。
0赞 journeywithjavascript 11/11/2023
就上下文而言,我只是在学习/掌握 html/css 的课程 - 实际上并没有尝试根据某些规范设计页面。我的目标是理解,而不是网页。
0赞 Sanxofon 11/11/2023
好的,我明白了。我将添加一些关于为什么会发生这种情况的一般解释。
0赞 journeywithjavascript 11/12/2023
我重新阅读了您的回答,感谢您抽出宝贵时间!它揭示了很多亮点,并且很有意义。一个后续问题 - 那么在 td 上显式设置宽度似乎不会覆盖其父级给它的默认值?其父级强加给它的价值优先?因为我认为,如果你在元素上显式设置一个值,它应该优先并覆盖它从其父元素继承的任何默认值。(对不起,细微差别的问题,只是想确保我彻底理解事情)
1赞 Sanxofon 11/14/2023
没问题,我是个好问题。据我所知,在优先顺序上可能存在重叠。在表的情况下,它们的行为(应该表现)非常特殊,不同于其他父子关系。TD 不应离开其对应的 TR,并且此 TR 不应离开其 TABLE。在CSS中,有几种类型的元素显示,边距,填充等,它们可以以多种方式产生相同的明显效果,也可以产生不可预测的效果。就表格而言,根据我的经验,它们的行为方式往往很奇怪,随着时间的推移,我更喜欢使用网格。