Tabela Bootstrap w paski: Jak zmienić kolor tła w paski?


Odpowiedzi:


116
.table-striped > tbody > tr:nth-child(2n+1) > td, .table-striped > tbody > tr:nth-child(2n+1) > th {
   background-color: red;
}

zmień tę linię w bootstrap.css lub możesz użyć (nieparzysty) lub (parzysty) zamiast (2n + 1)


100
Nie rób tego. Następnym razem, gdy zaktualizujesz bootstrap, stracisz niestandardowe nadpisanie. Znacznie lepiej jest mieć własny plik css w osobnym pliku, który umieścisz bezpośrednio po pliku bootstrap.css w głowie.
Ben Thurley

Jak zmieniłbyś kolor tła, aby najechać na cały wiersz w tym miejscu?
Barry Michael Doyle

2
ta strona wyjaśnia, jak to zrobić w przypadku najechania kursorem [ stackoverflow.com/questions/15643037/…
Yvon Huynh

4
To była odpowiedź, której potrzebowałem, jednak dodałem ją do osobnego pliku CSS, a nie do faktycznego CSS Bootstrap. Jest kaskadowy, więc jeśli dodam go po bootstrapie i działa idealnie i utrzymuje go z dala od głównego bootstrapa. Poza tym nie muszę nosić własnego zmodyfikowanego bootstrapu, zamiast tego po prostu dodaję mój css do każdego projektu, który tego potrzebuje.
raddevus,

Nigdy nie zmieniaj bezpośrednio żadnej biblioteki innej firmy. Nigdy! Po prostu nadpisz styl w swoim własnym pliku css.
Mehrdad

133

Dodaj następujący styl CSS po załadowaniu Bootstrap:

.table-striped>tbody>tr:nth-child(odd)>td, 
.table-striped>tbody>tr:nth-child(odd)>th {
   background-color: red; // Choose your own color here
 }

działa dobrze przy nadpisywaniu domyślnego koloru tablicy bootstrap. Dziękuję Ci.
euccas

To wyłącza klasę „table-hover” w parzystych wierszach ... czy jest rozwiązanie?
exSnake

14

Jeśli używasz Bootstrap 3, możesz użyć metody Florina lub użyć niestandardowego pliku CSS.

Jeśli używasz źródła bez Bootstrap zamiast przetworzonych plików css, możesz je bezpośrednio zmienić w bootstrap/less/variables.less.

Znajdź coś takiego:

//** Background color used for `.table-striped`.
@table-bg-accent:               #f9f9f9;

11

Masz dwie opcje, albo nadpisujesz style za pomocą niestandardowego arkusza stylów, albo edytujesz główny plik bootstrap css. Wolę to pierwsze.

Twoje niestandardowe style powinny być połączone po bootstrapie.

<link rel="stylesheet" src="bootstrap.css">
<link rel="stylesheet" src="custom.css">

W custom.css

.table-striped>tr:nth-child(odd){
   background-color:red;
}

Nie działa dla mnie. Odpowiedź kyriakos działa naprawdę dobrze.
varagrawal

W tym przykładzie brakuje tagu
tbody

> oznacza bezpośrednie dziecko, więc jeśli między tabelą a tr znajduje się znacznik tbody, to nie zadziała. ale po prostu usuń>, a będzie to obowiązywać dla wszystkich tr w określonej tabeli, bez względu na to, czy są bezpośrednimi dziećmi, czy nie.
jumps4fun

3

Nie dostosowuj swojego bootstrapowego CSS bezpośrednio edytując bootstrapowy plik CSS. Zamiast tego sugeruję skopiowanie wklejonego bootstrapowego CSS i zapisanie go w innym folderze CSS i tam możesz dostosować lub edytować style odpowiednie do twoich potrzeb.


3
.table-striped>tbody>tr:nth-child(odd)>td,
.table-striped>tbody>tr:nth-child(odd)>th {
  background-color: #e08283;
  color: white;
}
.table-striped>tbody>tr:nth-child(even)>td,
.table-striped>tbody>tr:nth-child(even)>th {
  background-color: #ECEFF1;
  color: white;
}

Użyj „even”, aby zmienić kolor parzystych rzędów, a „nieparzysty”, aby zmienić kolor nieparzystych wierszy.


To wyłącza klasę bootstrap-hover tabeli, czy jest sposób na użycie obu?
exSnake

3

Usuń paski tabeli Zastępuje próby zmiany koloru wiersza.

Następnie zrób to w css

   tr:nth-child(odd) {
    background-color: lightskyblue;
    }

   tr:nth-child(even) {
    background-color: lightpink;
    }

    th {
       background-color: lightseagreen;
    }

2

Ten wzór szachownicy (jako podzbiór paska zebry) jest dla mnie przyjemnym sposobem na wyświetlenie tabeli z dwiema kolumnami. Jest to napisane przy użyciu LESS CSS i kluczem wszystkie kolory poza kolorem podstawowym.

@base-color: #0000ff;
@row-color: lighten(@base-color, 40%);    
@other-row: darken(@row-color, 10%);

tbody {
    td:nth-child(odd) { width: 45%; }
    tr:nth-child(odd) > td:nth-child(odd) {
        background: darken(@row-color, 0%); }
    tr:nth-child(odd) > td:nth-child(even) {
        background: darken(@row-color, 7%); }
    tr:nth-child(even) > td:nth-child(odd) {
        background: darken(@other-row, 0%); }
    tr:nth-child(even) > td:nth-child(even) {
        background: darken(@other-row, 7%); }
}

Uwaga: upuściłem .table-striped, ale nie ma to znaczenia.

Wygląda jak: wprowadź opis obrazu tutaj


2

Z Bootstrap 4, odpowiedzialny konfiguracja w css bootstrap.cssza .table-stripedto:

.table-striped tbody tr:nth-of-type(odd) {
  background-color: rgba(0, 0, 0, 0.05);
}

Dla bardzo prostego rozwiązania po prostu skopiowałem go do swojego custom.csspliku i zmieniłem wartości background-color, dzięki czemu mam teraz bardziej wyszukany jasnoniebieski odcień:

.table-striped tbody tr:nth-of-type(odd) {
  background-color:  rgba(72, 113, 248, 0.068);
}

0

Jeśli chcesz faktycznie odwrócić kolory, powinieneś dodać regułę, która sprawi, że „nieparzyste” rzędy będą białe, a także sprawi, że „parzyste” rzędy będą miały dowolny kolor.


0

Najłatwiejszy sposób na zmianę kolejności pasków:

Dodaj puste tr przed tagami tr tabeli.

Korzystając z naszej strony potwierdzasz, że przeczytałeś(-aś) i rozumiesz nasze zasady używania plików cookie i zasady ochrony prywatności.
Licensed under cc by-sa 3.0 with attribution required.