Solved

CSS width not working in Firefox

Posted on 2008-11-03
3
443 Views
Last Modified: 2012-06-27
I found this piece of code on EE, it breaks a page up into simple tabs.

I've tried to adjust the width of the tabs by adding the width tag as below but it wont work in Firefox, it works perfecctly in Internet Explorer. Anyone any thoughts? Many thanks
<style type="text/css">
#tab1, #tab2, #tab3, #tab4 {display:none;}
.tabBtn {background:#ccc;width:200px;}
 
.showTab1 #tab1,
.showTab2 #tab2,
.showTab3 #tab3,
.showTab4 #tab4 {display:block;}
 
.showTab1 #tabBtn1,
.showTab2 #tabBtn2,
.showTab3 #tabBtn3,
.showTab4 #tabBtn4 {background:pink;}
</style>
<script type="text/javascript">
function setTab(num)
{
  document.getElementById('tabHolder').className = 'showTab' + num;
}
</script>
<div id="tabHolder" class="showTab1">
  <a href="#" id="tabBtn1" class="tabBtn" onclick="setTab(1)">Tab 1</a>
  <a href="#" id="tabBtn2" class="tabBtn" onclick="setTab(2)">Tab 2</a>
  <a href="#" id="tabBtn3" class="tabBtn" onclick="setTab(3)">Tab 3</a>
  <a href="#" id="tabBtn4" class="tabBtn" onclick="setTab(4)">Tab 4</a>
  <table id="tab1">
    <tr><th>Data1</th></tr>
  </table>
  <table id="tab2">
    <tr><th>Data2</th></tr>
  </table>
  <table id="tab3">
    <tr><th>Data3</th></tr>
  </table>
  <table id="tab4">
    <tr><th>Data4</th></tr>
  </table>
</div>

Open in new window

0
Comment
Question by:kbit
3 Comments
 
LVL 3

Accepted Solution

by:
SreejithG earned 250 total points
ID: 22865960
Use padding (padding-right) instead of width. Code attached.

regards,
Sreejith
<style type="text/css">
#tab1, #tab2, #tab3, #tab4 {display:none;}
.tabBtn {background:#ccc;padding-right:200px;	}
 
.showTab1 #tab1,
.showTab2 #tab2,
.showTab3 #tab3,
.showTab4 #tab4 {display:block;}
 
.showTab1 #tabBtn1,
.showTab2 #tabBtn2,
.showTab3 #tabBtn3,
.showTab4 #tabBtn4 {background:pink;}
</style>
<script type="text/javascript">
function setTab(num)
{
  document.getElementById('tabHolder').className = 'showTab' + num;
}
</script>
<div id="tabHolder" class="showTab1">
  <a href="#" id="tabBtn1" class="tabBtn" onclick="setTab(1)">Tab 1</a>
  <a href="#" id="tabBtn2" class="tabBtn" onclick="setTab(2)">Tab 2</a>
  <a href="#" id="tabBtn3" class="tabBtn" onclick="setTab(3)">Tab 3</a>
  <a href="#" id="tabBtn4" class="tabBtn" onclick="setTab(4)">Tab 4</a>
  <table id="tab1">
    <tr><th>Data1</th></tr>
  </table>
  <table id="tab2">
    <tr><th>Data2</th></tr>
  </table>
  <table id="tab3">
    <tr><th>Data3</th></tr>
  </table>
  <table id="tab4">
    <tr><th>Data4</th></tr>
  </table>
</div>

Open in new window

0
 
LVL 7

Assisted Solution

by:Valleriani
Valleriani earned 250 total points
ID: 22865976
I have used padding for this:

padding:0px 52px; <-- change the 52px and it will set.

With the first number can change the height a bit, though it will clash if you don't move down the data.

Second number is the padding width, it will stay centered.
<style type="text/css">
#tab1, #tab2, #tab3, #tab4 {display:none;}
.tabBtn {
background:#ccc;
padding:0px 52px;
}
 
.showTab1 #tab1,
.showTab2 #tab2,
.showTab3 #tab3,
.showTab4 #tab4 {display:block;}
 
.showTab1 #tabBtn1,
.showTab2 #tabBtn2,
.showTab3 #tabBtn3,
.showTab4 #tabBtn4 {background:pink;}
</style>
<script type="text/javascript">
function setTab(num)
{
  document.getElementById('tabHolder').className = 'showTab' + num;
}
</script>
<div id="tabHolder" class="showTab1">
  <a href="#" id="tabBtn1" class="tabBtn" onclick="setTab(1)">Tab 1</a>
  <a href="#" id="tabBtn2" class="tabBtn" onclick="setTab(2)">Tab 2</a>
  <a href="#" id="tabBtn3" class="tabBtn" onclick="setTab(3)">Tab 3</a>
  <a href="#" id="tabBtn4" class="tabBtn" onclick="setTab(4)">Tab 4</a>
  <table id="tab1">
    <tr><th>Data1</th></tr>
  </table>
  <table id="tab2">
    <tr><th>Data2</th></tr>
  </table>
  <table id="tab3">
    <tr><th>Data3</th></tr>
  </table>
  <table id="tab4">
    <tr><th>Data4</th></tr>
  </table>
</div>

Open in new window

0
 

Author Comment

by:kbit
ID: 22866164
Many thanks both, I've taken inspiration from each of you!
0

Featured Post

Free Tool: ZipGrep

ZipGrep is a utility that can list and search zip (.war, .ear, .jar, etc) archives for text patterns, without the need to extract the archive's contents.

One of a set of tools we're offering as a way to say thank you for being a part of the community.

Question has a verified solution.

If you are experiencing a similar issue, please ask a related question

Suggested Solutions

Styling your websites can become very complex. Here I'll show how SASS can help you better organize, maintain and reuse your CSS code.
Browsers only know CSS so your awesome SASS code needs to be translated into normal CSS. Here I'll try to explain what you should aim for in order to take full advantage of SASS.
In this Micro Tutorial users will learn how to embed custom fonts into websites using @font-face in CSS Select a font: Ensure the EULA allows you to use @font-face: Download the font: Get the browser-compatible files you need: Edit your CSS       - Name …
In this tutorial viewers will learn how to style elements, such a divs, with a "drop shadow" effect using the CSS box-shadow property Start with a normal styled element, such as a div.: In the element's style, type the box shadow property: "box-shad…

749 members asked questions and received personalized solutions in the past 7 days.

Join the community of 500,000 technology professionals and ask your questions.

Join & Ask a Question