wake-up-neo.com

Box-Schatten auf Tabellenzeilen erscheint in bestimmten Browsern nicht

CSS-Box-Schatten in Tabellenzeilen - tr - scheint nicht in allen Browsern konsistent zu funktionieren. Bei einigen Browsern wird der Schatten angezeigt. Bei anderen gibt es keinen Schatten.

Ich verwende folgendes CSS:

tr {
  background-color: rgb(165, 182, 229);
  box-shadow: 0px 2px 2px black;
  -moz-box-shadow: 0px 2px 2px black;
  -webkit-box-shadow: 0px 2px 2px black;
}
td, th {
  padding: 5px;
  text-align: left;
}

Hier ist ein jsFiddle des folgenden Snippets:

tr {
  background-color: rgb(165, 182, 229);
  box-shadow: 0px 2px 2px black;
  -moz-box-shadow: 0px 2px 2px black, ;
  -webkit-box-shadow: 0px 2px 2px black;
}
td, th {
  padding: 5px;
  text-align: left;
}
<table>
  <tr>
    <td>&nbsp;</td>
    <th>One</th>
    <th>Two</th>
  </tr>
  <tr>
    <th>Title</th>
    <td>Three</td>
    <td>Four</td>
  </tr>
  <tr>
    <th>Title2</th>
    <td>Five</td>
    <td>Six</td>
  </tr>
  <tr>
    <th>Title3</th>
    <td>Seven</td>
    <td>Eight</td>
  </tr>
  <tr>
    <th>Title4</th>
    <td>Nine</td>
    <td>Ten</td>
  </tr>
</table>

Hinweis: Das gleiche Verhalten wird beobachtet, wenn Sie <tr> durch <div> ersetzen und display: table-row hinzufügen.

25
George

Wie bereits erwähnt, funktioniert die box-shadow-Eigenschaft nur mit Elementen, die display: block oder display:inline-block-Eigenschaft haben.

Wenn Sie der Tabellenzelle als allgemeine Stilregel display: block hinzufügen, wird diese ausgeblendet, da die automatischen Breiten-/Höhenproportionen der Zellen mit display:table nicht mehr angewendet werden. Um dieses Verhalten zu simulieren, weisen Sie jeder th und td ein min-width-Attribut zu.

Dann wende box-shadow auf die Zeile an (im Hover oder außerhalb).

Zusammenfassend sollte Ihr Code so aussehen:

table { box-sizing: border-box; }
td, th { padding-left: 16px; min-width: 170px; text-align: left; }
tr { display: block; }
tr:hover { box-shadow: 0px 2px 18px 0px rgba(0,0,0,0.5); cursor: pointer; }

Ich habe der Einfachheit halber Herstellerpräfixe weggelassen.

Hier ist das vollständige Beispiel:

table {
  box-sizing: border-box;
  border-bottom: 1px solid #e8e8e8;
}
td,
th {
  padding-left: 16px;
  min-width: 170px;
  border: 1px solid #e8e8e8;
  border-bottom: none;
  font: 14px/40px;
  text-align: left;
}
td {
  color: #666;
}
tr {
  display: block;
}
th {
  color: #333;
}
tr:hover {
  background-color: #fbfbfb;
  box-shadow: 0px 2px 18px 0px rgba(0, 0, 0, 0.5);
  cursor: pointer;
}
<table cellpadding="0" cellspacing="0">
  <thead>
    <tr>
      <th>Phone number</th>
      <th>Date</th>
      <th>Name</th>
      <th>Label</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>0342443</td>
      <td>10 August 2013</td>
      <td>Kate</td>
      <td>Loves cats</td>
      </td>
      <tr>
        <td>0342442</td>
        <td>9 August 2013</td>
        <td>Mary</td>
        <td>Boring</td>
      </tr>
      <tr>
        <td>0342441</td>
        <td>8 August 2013</td>
        <td>Anna</td>
        <td>Loves extreme stuff</td>
      </tr>
  </tbody>
</table>

Sie können auch die Geige hier überprüfen .

29

Bitte markieren Sie diesen Fehler, wenn Sie möchten, dass er behoben wird:

https://code.google.com/p/chromium/issues/detail?id=94871

Wenn Sie möchten, dass sich die Breiten der Tabellenzellen automatisch weiter anpassen, können Sie stattdessen den Schatten auf die einzelnen Zellen anwenden:

td:first-child {
  box-shadow:
    inset 0px 11px 8px -10px blue,
    inset 0px -11px 8px -10px blue,
    inset 11px 0px 8px -10px blue; 
}
td {
  box-shadow:
    inset 0px 11px 8px -10px blue,
    inset 0px -11px 8px -10px blue;
}
td:last-child {
  box-shadow:
    inset 0px 11px 8px -10px blue,
    inset 0px -11px 8px -10px blue,
    inset -11px 0px 8px -10px blue; 
}

Vollständiges Beispiel hier . (jsfiddle)

(Inspiriert von https://stackoverflow.com/a/10150898/724752 )

In jedem Feld Schattenwert:

  • Passen Sie die 3. Zahl (Unschärfekreis) an, um den Unschärfekreis zu ändern.
  • Die 4. Zahl (Ausbreitungsradius) muss immer negativ sein und ihr absoluter Wert muss größer sein als die 3. Zahl (Unschärfekreis).
  • Stellen Sie die 1. Zahl (Versatz x) ungleich Null ein, um links oder rechts einen Schatten zu erhalten. Stellen Sie den absoluten Wert 1 größer als den absoluten Wert der 4. Zahl ein (siehe obiges Beispiel, viel einfacher zu sehen, was ich meine).
  • Stellen Sie die zweite Zahl (Versatz y) ungleich Null ein, um einen Schatten oben oder unten zu erhalten. Stellen Sie den absoluten Wert 1 größer als den absoluten Wert der 4. Zahl ein.
9
David Winiecki

Verwenden Sie die Eigenschaft transform scale (1,1) mit Box-Shadow, um das Problem zu lösen.

tr:hover {
  transform: scale(1);
  -webkit-transform: scale(1);
  -moz-transform: scale(1);
  box-shadow: 0px 0px 5px rgba(0,0,0,0.3);
  -webkit-box-shadow: 0px 0px 5px rgba(0,0,0,0.3);
  -moz-box-shadow: 0px 0px 5px rgba(0,0,0,0.3);
}

Geige: https://jsfiddle.net/ampicx/5p91xr48/

Vielen Dank!!

7
Anurag Malhotra

Ich hatte das gleiche Problem. Ich habe versucht, eine ganze Reihe hervorzuheben, wenn sich die Maus darüber befindet. Unten ist der CSS-Code dafür:

tr:hover {
    outline: none;
    -webkit-box-shadow: inset 0 0 10px #337AB7;
    box-shadow: inset 0 0 10px #337AB7;
}

Es funktioniert einwandfrei unter Mozilla Firefox (38.0.1) und Internet Explorer (11.0.9600.17801), beide unter Windows 7. Allerdings nicht unter Chrome (43.0.2357.81).

Daher musste ich einen Workaround durchführen und die Antworten von Sviatoslav Zalishchuk und David Winiecki gemischt beantworten. Als Ergebnis bekam ich:

@media screen and (-webkit-min-device-pixel-ratio:0) {
    tr:hover td:first-child {
       box-shadow: inset 0px 11px 8px -10px #337AB7, 
                   inset 0px -11px 8px -10px #337AB7, 
                   inset 11px 0px 8px -10px #337AB7;
    }

    tr:hover td {
       box-shadow: inset 0px 11px 8px -10px #337AB7, 
                   inset 0px -11px 8px -10px #337AB7;
    }

    tr:hover td:last-child {
       box-shadow: inset 0px 11px 8px -10px #337AB7, 
                   inset 0px -11px 8px -10px #337AB7, 
                   inset -11px 0px 8px -10px #337AB7;
    }
}

tbody > tr:hover {
    outline: none;
    -webkit-box-shadow: inset 0 0 10px #337AB7;
    box-shadow: inset 0 0 10px #337AB7;
}

Das funktioniert einwandfrei und bricht die Spaltenbreite der Tabelle nicht und funktioniert immer noch unter Mozilla und Explorer. 

Unten ist ein vollständiges Beispiel:

table {
  box-sizing: border-box;
  border-collapse: collapse;
}
td,
th {
  padding-left: 10px;
  padding-right: 10px;
  border: 1px solid #dddddd;
  font: 14px;
  text-align: left;
}

/*To work only on Chrome and Safari*/
@media screen and (-webkit-min-device-pixel-ratio:0) {
  tr:hover td:first-child {
    box-shadow: inset 0px 11px 8px -10px #337AB7, 
      inset 0px -11px 8px -10px #337AB7, 
      inset 11px 0px 8px -10px #337AB7;
  }

  tr:hover td {
    box-shadow: inset 0px 11px 8px -10px #337AB7, 
      inset 0px -11px 8px -10px #337AB7;
  }

  tr:hover td:last-child {
    box-shadow: inset 0px 11px 8px -10px #337AB7, 
      inset 0px -11px 8px -10px #337AB7, 
      inset -11px 0px 8px -10px #337AB7;
  }
}

/*To work on the others browsers*/
tbody > tr:hover {
  outline: none;
  -webkit-box-shadow: inset 0 0 10px #337AB7;
  box-shadow: inset 0 0 10px #337AB7;
}
<table>
  <thead>
    <tr>
      <th>Name</th>
      <th>Born</th>
      <th>City</th>      
    </tr>
  </thead>
  <tbody>
    <tr>
      <td>David Gilmour</td>
      <td>6 March 1946</td>
      <td>Cambridge, England</td> 
	</tr>
    <tr>
      <td>Roger Waters</td>
      <td>6 September 1943</td>
      <td>Surrey, England</td>		
    </tr>
    <tr>
      <td>Nick Mason</td>
      <td>27 January 1944</td>
      <td>Birmingham, England</td>
    </tr>
    <tr>
      <td>Richard Wright</td>
      <td>28 July 1943</td>
      <td>London, England</td>
    </tr>
  </tbody>
</table>

4

Die Gründe dafür scheinen auf Standard-CSS zurückzuführen zu sein - der display: block war der größte Faktor.

CSS/HTML/Demo

tr {
  background-color: rgb(165, 182, 229);
  display: block;
  margin-bottom: 5px;
  -moz-box-shadow: 0px 2px 2px black;
  -webkit-box-shadow: 0px 2px 2px black;
  box-shadow: 0px 2px 2px black;
}
td,th {
  padding: 5px;
  text-align: left;
}
<table>
  <tr>
    <td>&nbsp;</td>
    <th>One</th>
    <th>Two</th>
  </tr>
  <tr>
    <th>Title</th>
    <td>Three</td>
    <td>Four</td>
  </tr>
  <tr>
    <th>Title2</th>
    <td>Five</td>
    <td>Six</td>
  </tr>
  <tr>
    <th>Title3</th>
    <td>Seven</td>
    <td>Eight</td>
  </tr>
  <tr>
    <th>Title4</th>
    <td>Nine</td>
    <td>Ten</td>
  </tr>
</table>

4
Ian Wood

In v53 Chrome wurde es nun behoben und Box-Shadow funktioniert gut für <tr></tr>!

CSS/HTML/Demo

table {
  border-spacing: 0 10px;
  border-collapse: separate;
} 
tbody {
  display: table-row-group;
  vertical-align: middle;
}
tr {
  margin-bottom: 9px;
}
tr:hover {
      box-shadow: 0 5px 8px 0 rgba(50, 50, 50, 0.35);
    -webkit-box-shadow: 0 5px 8px 0 rgba(50, 50, 50, 0.35);
    -moz-box-shadow: 0 5px 8px 0 rgba(50, 50, 50, 0.35);
}
<table class="table">
  <caption>Optional table caption.</caption>
  <thead> 
    <tr> 
      <th>#</th>
      <th>First Name</th>
      <th>Last Name</th>
      <th>Username</th>
    </tr>
  </thead>
  <tbody>
    <tr>
      <th scope="row">1</th>
      <td>Mark</td>
      <td>Otto</td>
      <td>@mdo</td>
    </tr>
    <tr>
      <th scope="row">2</th>
      <td>Jacob</td>
      <td>Thornton</td>
      <td>@fat</td>
    </tr>
    <tr> 
      <th scope="row">3</th>
      <td>Larry</td>
      <td>the Bird</td>
      <td>@Twitter</td>
    </tr>
  </tbody>
</table>

1
S-Kerrigan

ich habe die Antwort wie folgt kombiniert. Es hat gut funktioniert in Chrom,> Firefox, dh11

.select_row{
    color: #43B149;
    font-weight: bolder !important;
    background: #e4e5e6 !important;
    box-shadow: 1px 0px 1px 0px #cad6ce !important;
    -moz-box-shadow:1px 0px 1px 0px #cad6ce !important;
    -webkit-box-shadow:1px 0px 1px 0px #cad6ce !important;
    transform: scale(1);
    -webkit-transform: scale(1);
    -moz-transform: scale(1);
    -ms-transform: scale(1);
    td{box-shadow: 0px 3px 0px 0px #cad6ce !important;
        -moz-box-shadow:0px 3px 0px 0px #cad6ce !important;
        -webkit-box-shadow:0px 3px 0px 0px #cad6ce !important;
        background: #e4e5e6 !important;
    }
}
.table-forecast{
    border-collapse: separate;
    border-spacing: 0px;
}
0
VoHinh

Ich wollte einen Box-Schatten auf der linken Seite der Reihe, wenn er schwebte:

 enter image description here

Ich habe es einfach behoben, indem ich den Box-Schatten auf die erste Zelle in der Reihe gesetzt habe. So was:

tr:hover                { background: #EEF0F3; cursor: pointer; }
tr:hover td:first-child { box-shadow: inset 2px 0 0 0 #323335; }

Ich habe es in Firefox, Chrome und IE9 versucht. Scheint gut zu funktionieren.


Wenn Sie einen 1px breiten Rand um die ganze Reihe möchten, können Sie Folgendes tun:

tr:hover td             { box-shadow: 0 1px 0 0 black, 0 -1px 0 0 black; }
tr:hover td:first-child { box-shadow: 0 -1px 0 0 black, -1px 0 0 0 black, 0 1px 0 0 black; }
tr:hover td:last-child  { box-shadow: 0 -1px 0 0 black, 1px 0 0 0 black, 0 1px 0 0 black; }

 enter image description here

0
A.D