显示中的单元格宽度:表格

时间:2018-05-08 05:14:42

标签: html css position border css-tables

我使用display: table布局创建卡片。这是我到目前为止的尝试:

.panel-bg {
  background-color: #F8F8F8; 
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 24px 0;
}

.panel {
  width: calc(100%-32px);
  height: 100%;
  border-radius: 3px;
  background-color: #fff;
  box-shadow: 0px 3px 6px 0 rgba(0,0,0,0.15);
  font-size: 16px;
  cursor: pointer;
  margin: 0 16px;
}

.panel-title-row {
  display: table-row;
  width: 100%;
  border-collapse: collapse;
  border-bottom: solid 1px #c4c4c4;
}

.panel-title {
  display: table-cell;
  width: 80%;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 700;
  color: #0099ff;
  padding: 24px;
}

.panel-action {
  text-align: right;
  width: 20%;
  display: table-cell;
}

.panel-action li {
  margin-left: 16px;
}

.panel-action li:last-child {
  margin-left: 32px; 
}

.col-1,
.col-2,
.col-3 {
  width: 33.33%; 
  display: table-cell;
  padding: 24px;
}

.panel-data {
  margin-top: 16px; 
}

.panel-data-label {
  font-weight: 700;
  font-size: 12px;
}

.panel-data-value {
  font-size: 13px; 
  margin-top: 8px;
}

.panel-content {
  display: table-row;
  width: 100%;
}

.panel-data-vertical {
  display: table;
  width: 100%;
}

.panel-data-vertical .panel-data-label,
.panel-data-vertical .panel-data-value {
  display: table-cell;
  width: 50%;
}

ul {
  list-style-type: none;
}

ul li {
  display: inline-block;
}
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.11/css/all.css" integrity="sha384-p2jx59pefphTFIpeqCcISO9MdVfIm4pNnsL08A6v5vaQc4owkQqxMV8kg4Yvhaw/" crossorigin="anonymous">
<link href="https://fonts.googleapis.com/css?family=Open+Sans:400,400i,700,700i" rel="stylesheet">

<div class="panel-bg">

<div class="panel">
  <div class="panel-title-row">
    <div class="panel-title">
      Members
    </div>
    <ul class="panel-action">
      <li><i class="fas fa-pencil-alt"></i></li>
      <li><i class="fas fa-trash"></i></li>
      <li><i class="fas fa-chevron-down"></i></li>
    </ul>
  </div>
  <div class="panel-content">
    <div class="col-1">
      <div class="panel-data panel-data-horizontal">
        <div class="panel-data-label">
          Effective Date
        </div>
        <div class="panel-data-value">
          1 Jan 2018
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Employment Type
        </div>
        <div class="panel-data-value">
          Permanent
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Job Level
        </div>
        <div class="panel-data-value">
          Staff
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Job Title
        </div>
        <div class="panel-data-value">
          All
        </div>
      </div>
    </div>
    <div class="col-2">
      
    </div>
    <div class="col-3">
      
    </div>
  </div>
</div>
  
</div>

我的问题是:

  1. 我想将border-bottom放到panel-title-row,但它没有显示。我想左边和右边填充边框(大约24像素),但每当我将填充属性或border-bottom添加到行或其子代时,它似乎不起作用。
  2. panel-title-row的孩子不会将父母的宽度填充到100%,尽管我为每个孩子设置了80%和20%。当我更改百分比时,它会影响不属于该行的col-1
  3. 我在table-row(名为panel-title)下方创建了另一个panel-content,我想将其划分为3个具有相同宽度的列(名为col-1,{{1 }}和col-2)但col-3不起作用。
  4. 这就是我想要实现的目标,重点是卡和线之间的空间。

    enter image description here

    任何帮助表示赞赏!

1 个答案:

答案 0 :(得分:1)

希望这对你有所帮助,你是否希望只使用表格来完成它?

&#13;
&#13;
.panel-bg {
  background-color: #F8F8F8; 
  height: 100%;
  width: 100%;
  margin: 0;
  padding: 24px 0;
}

.panel {
  width: calc(100%-32px);
  height: 100%;
  border-radius: 3px;
  background-color: #fff;
  box-shadow: 0px 3px 6px 0 rgba(0,0,0,0.15);
  font-size: 16px;
  cursor: pointer;
  margin: 0 16px;
padding:25px;
}

.panel-title-row {
  display: block;
  width: 100%;
  border-collapse: collapse;
  border-bottom: solid 1px #c4c4c4;
}

.panel-title {
  display: inline-block;
  width: 78%;
  text-transform: uppercase;
  font-size: 14px;
  font-weight: 700;
  color: #0099ff;
  padding: 0;
}

.panel-action {
  text-align: right;
  width: 20%;
  display: inline-block;
padding:0px 5px 15px 0;
margin:0;
}

.panel-action li {
  margin-left: 10px;
}

.panel-action li:last-child {
  margin-left: 29px; 
}

.col-1,
.col-2,
.col-3 {
  width: 33.33%; 
  display: table-cell;
  padding: 5px 0px 20px 0px;
}

.panel-data {
  margin-top: 16px; 
}

.panel-data-label {
  font-weight: 700;
  font-size: 12px;
}

.panel-data-value {
  font-size: 13px; 
  margin-top: 8px;
}

.panel-content {
  display: table-row;
  width: 100%;
}

.panel-data-vertical {
  display: table;
  width: 100%;
}

.panel-data-vertical .panel-data-label,
.panel-data-vertical .panel-data-value {
  display: table-cell;
  width: 50%;
}

ul {
  list-style-type: none;
}

ul li {
  display: inline-block;
}
&#13;
<link rel="stylesheet" href="https://use.fontawesome.com/releases/v5.0.11/css/all.css" integrity="sha384-p2jx59pefphTFIpeqCcISO9MdVfIm4pNnsL08A6v5vaQc4owkQqxMV8kg4Yvhaw/" crossorigin="anonymous">
<link href="https://fonts.googleapis.com/css?family=Open+Sans:400,400i,700,700i" rel="stylesheet">

<div class="panel-bg">

<div class="panel">
  <div class="panel-title-row">
    <div class="panel-title">
      Members
    </div>
    <ul class="panel-action">
      <li><i class="fas fa-pencil-alt"></i></li>
      <li><i class="fas fa-trash"></i></li>
      <li><i class="fas fa-chevron-down"></i></li>
    </ul>
  </div>
  <div class="panel-content">
    <div class="col-1">
      <div class="panel-data panel-data-horizontal">
        <div class="panel-data-label">
          Effective Date
        </div>
        <div class="panel-data-value">
          1 Jan 2018
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Employment Type
        </div>
        <div class="panel-data-value">
          Permanent
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Job Level
        </div>
        <div class="panel-data-value">
          Staff
        </div>
      </div>
      <div class="panel-data panel-data-vertical">
        <div class="panel-data-label">
          Job Title
        </div>
        <div class="panel-data-value">
          All
        </div>
      </div>
    </div>
    <div class="col-2">
      
    </div>
    <div class="col-3">
      
    </div>
  </div>
</div>
  
</div>
&#13;
&#13;
&#13;