Domanda temi dell'interfaccia utente jQuery e tabelle HTML


C'è un modo per creare temi con una tabella HTML (CSS) usando i temi jQuery CSS?

Tutti i miei componenti sembrano appartenere insieme tranne che per la mia tabella HTML che sembra diversa.


44
2018-04-10 14:03


origine


risposte:


Ci sono un sacco di risorse là fuori:

Plugin con supporto ThemeRoller:

jqGrid

DataTables.net

AGGIORNAMENTO: ecco qualcosa che ho messo insieme per modellare la tabella:

<script type="text/javascript">

    (function ($) {
        $.fn.styleTable = function (options) {
            var defaults = {
                css: 'styleTable'
            };
            options = $.extend(defaults, options);

            return this.each(function () {

                input = $(this);
                input.addClass(options.css);

                input.find("tr").live('mouseover mouseout', function (event) {
                    if (event.type == 'mouseover') {
                        $(this).children("td").addClass("ui-state-hover");
                    } else {
                        $(this).children("td").removeClass("ui-state-hover");
                    }
                });

                input.find("th").addClass("ui-state-default");
                input.find("td").addClass("ui-widget-content");

                input.find("tr").each(function () {
                    $(this).children("td:not(:first)").addClass("first");
                    $(this).children("th:not(:first)").addClass("first");
                });
            });
        };
    })(jQuery);

    $(document).ready(function () {
        $("#Table1").styleTable();
    });

</script>

<table id="Table1" class="full">
    <tr>
        <th>one</th>
        <th>two</th>
    </tr>
    <tr>
        <td>1</td>
        <td>2</td>
    </tr>
    <tr>
        <td>1</td>
        <td>2</td>
    </tr>
</table>

Il CSS:

.styleTable { border-collapse: separate; }
.styleTable TD { font-weight: normal !important; padding: .4em; border-top-width: 0px !important; }
.styleTable TH { text-align: center; padding: .8em .4em; }
.styleTable TD.first, .styleTable TH.first { border-left-width: 0px !important; }

59
2018-04-12 21:17



dochoffiday di risposta è un ottimo punto di partenza, ma per me non è stato tagliato (la parte CSS aveva bisogno di un buff), quindi ho apportato una versione modificata con diversi miglioramenti.

Guardalo in azione, poi torna per la descrizione.

JavaScript

(function ($) {
    $.fn.styleTable = function (options) {
        var defaults = {
            css: 'ui-styled-table'
        };
        options = $.extend(defaults, options);

        return this.each(function () {
            $this = $(this);
            $this.addClass(options.css);

            $this.on('mouseover mouseout', 'tbody tr', function (event) {
                $(this).children().toggleClass("ui-state-hover",
                                               event.type == 'mouseover');
            });

            $this.find("th").addClass("ui-state-default");
            $this.find("td").addClass("ui-widget-content");
            $this.find("tr:last-child").addClass("last-child");
        });
    };
})(jQuery);

Differenze con la versione originale:

  • la classe CSS predefinita è stata modificata in ui-styled-table (sembra più coerente)
  • il .live la chiamata è stata sostituita con la raccomandata .on per jQuery 1.7 verso l'alto
  • il condizionale esplicito è stato sostituito da .toggleClass (un equivalente terser)
  • codice che imposta la classe CSS erroneamente chiamata first sulle celle della tabella è stato rimosso
  • il codice che aggiunge dinamicamente .last-child all'ultima riga della tabella è necessario correggere un problema visivo su Internet Explorer 7 e Internet Explorer 8; per i browser che supportano :last-child non è necessario

CSS

/* Internet Explorer 7: setting "separate" results in bad visuals; all other browsers work fine with either value. */
/* If set to "separate", then this rule is also needed to prevent double vertical borders on hover:
table.ui-styled-table tr * + th, table.ui-styled-table tr * + td  { border-left-width: 0px !important; } */
table.ui-styled-table { border-collapse: collapse; }

/* Undo the "bolding" that jQuery UI theme may cause on hovered elements
/* Internet Explorer 7: does not support "inherit", so use a MS proprietary expression along with an Internet Explorer <= 7 targeting hack
        to make the visuals consistent across all supported browsers */
table.ui-styled-table td.ui-state-hover {
    font-weight: inherit;
    *font-weight: expression(this.parentNode.currentStyle['fontWeight']);
}

/* Initally remove bottom border for all cells. */
table.ui-styled-table th, table.ui-styled-table td { border-bottom-width: 0px !important; }

/* Hovered-row cells should show bottom border (will be highlighted) */
table.ui-styled-table tbody tr:hover th,
table.ui-styled-table tbody tr:hover td
{ border-bottom-width: 1px !important; }

/* Remove top border if the above row is being hovered to prevent double horizontal borders. */
table.ui-styled-table tbody tr:hover + tr th,
table.ui-styled-table tbody tr:hover + tr td
{ border-top-width: 0px !important; }

/* Last-row cells should always show bottom border (not necessarily highlighted if not hovered). */
/* Internet Explorer 7, Internet Explorer 8: selector dependent on CSS classes because of no support for :last-child */
table.ui-styled-table tbody tr.last-child th,
table.ui-styled-table tbody tr.last-child td
{ border-bottom-width: 1px !important; }

/* Last-row cells should always show bottom border (not necessarily highlighted if not hovered). */
/* Internet Explorer 8 BUG: if these (unsupported) selectors are added to a rule, other selectors for that rule will stop working as well! */
/* Internet Explorer 9 and later, Firefox, Chrome: make sure the visuals are working even without the CSS classes crutch. */
table.ui-styled-table tbody tr:last-child th,
table.ui-styled-table tbody tr:last-child td
{ border-bottom-width: 1px !important; }

Gli appunti

Ho testato questo su Internet Explorer 7 e versioni successive, Firefox 11 e Google Chrome 18 e ho confermato che funziona perfettamente. io ho non testato versioni ragionevolmente precedenti di Firefox e Chrome o qualsiasi versione di musica lirica; tuttavia, quei browser sono ben noti per il buon supporto CSS e dal momento che non stiamo usando alcuna funzionalità di bleeding qui presumo che funzionerà bene anche lì.

Se non sei interessato al supporto di Internet Explorer 7, è disponibile un solo attributo CSS (introdotto con lo star hack).

Se non sei interessato al supporto di Internet Explorer 8, il CSS e JavaScript correlato all'aggiunta e al targeting di last-child Anche la classe CSS può andare.


31
2018-04-02 11:06



Perché noy basta usare gli stili del tema nella tabella? cioè

<table>
  <thead class="ui-widget-header">
    <tr>
      <th>Id</th>
      <th>Description</th>
    </td>
  </thead>
  <tbody class="ui-widget-content">
    <tr>
      <td>...</td>
      <td>...</td>
    </tr>
      .
      .
      .
  </tbody>
</table>

E non hai bisogno di usare alcun codice ...


17
2018-05-27 18:28