开发者

Ways to hide first column of table through CSS

开发者 https://www.devze.com 2022-12-13 17:18 出处:网络
T开发者_开发知识库his code is working on browsers other than IE: table.tbl.tr.td:first-child { display: none; }

T开发者_开发知识库his code is working on browsers other than IE:

table.tbl.tr.td:first-child { display: none; }

What shall I use for to make it work on all browsers?


Your expression above won't work at all. table.tbl.tr.td will select a table element that is defined like this: <table class="tbl tr td"> but not its cells.

It should be like this and the :first-child selector is supported in pretty much all browsers above Internet Explorer 6:

table.tbl tr td:first-child { display: none; }


Unfortunately, older versions of IE do not support :first-child in CSS. Don't know about IE8. Anyways, if you don't want to do javascript, and you have access to the html, it's pretty easy to assign a "first" class to the first column tds in the table. So the html will look like:

<table>
  <tr>
    <td class="first">...</td>
    <td>..</td>
    ..
  </tr>
</table>

You can then create a css entry like:

table td.first { display: none; }


Hide first column

table td:nth-child(1){ display:none;} 

Works OK in Chrome + FireFox but not in IE

Use Jquery to handle cross platform issues using:

$('table td:nth-child(1)').hide();

works in all browsers!


Simply use:

table td:nth-child(n){
   display:none;
}

Where n is the column you want to hide.

Here is an usage example:

table.marks.hideSubject       {td:nth-child(1) {display: none;}}
table.marks.hideDescription   {td:nth-child(2) {display: none;}}
table.marks.hideMark          {td:nth-child(3) {display: none;}}
table.marks.hideRank          {td:nth-child(4) {display: none;}}


Well, the short answer is you can't get this working in earlier versions of IE. I'm guessing IE8 would handle it. There's a CSS hack called expressions that would solve the issue but expressions are such a bad idea I won't even show you how to do it.

Keep your CSS the way it is, and add a JavaScript that does the same for you on DOMReady if the client is on IE.


Sadly, very little can be done. <colgroup> seems tempting, but browsers treat it differently.
You may have to manually add a class for each cell, or use JavaScript.


For IE you should/could be able set up col and colspans for your table columns then hide those in CSS.

As far as I know this will only work in IE, which (for once, to it's credit) has the best implementation of col and colspan. Other browsers are weak here (but it's a very minor part of the spec)


By using CSS nth-child we can hide the columns. Just need to specify the TABLE ID and Column Indexes.
In this example i am hiding last 3 columns of the table.

<style>
    #ID_OF_THE_TABLE tr *:nth-child(10),tr *:nth-child(9),tr *:nth-child(8){
        display: none;
    }
</style>


the solutions, that worked for me, was:

td { display: none; }
td + td { display: table-cell; }

No need of JavaScript, no need of an extra class.

Cheers

0

精彩评论

暂无评论...
验证码 换一张
取 消