www.alistapart.com/articles/slidingdoors
CSS2s current state requires a separate HTML element for each background image. In many cases, typical markup for common interface components has already provided several elements for our use. Its time to take back control over the tabs which are continually growing in popularity as a primary means of site navigation. Now that CSS is widely supported, we can crank up the quality and appearance of the tabs on our sites. Youre most likely aware that CSS can be used to tame a plain unordered list . Maybe youve even seen lists styled as tabs, looking something like this: What if we could take the exact same markup from the tabs above, and turn them into something like this: With simple styling, we can . Many of the CSS-based tabs Ive seen suffer from the same generic features: blocky rectangles of color, maybe an outline, a border disappears for the current tab, a color changes for the hover state. Prior to a more widespread adoption of CSS, we started seeing a lot of innovation in navigation design. Creative shapes, masterful color blending, and mimicry of physical interfaces from the real world. But these designs often relied heavily on a complex construction of text-embedded images, or were wrapped with multiple nested tables. Text resizing was impossible, or caused significant problems with page layout. Pure text navigation is much easier to maintain and loads more quickly than text-as-image navigation. Also, even though we can add alt attributes to each image, pure text is even more accessible since it can be resized by users with impaired vision. Its no wonder that pure text-based navigation, styled with CSS, is leaping back into web design. But most CSS-based tab design so far is a step back in appearance from what we used to do certainly nothing to be included in a design portfolio. A newly adopted technology like CSS should allow us to create something better , without losing the design quality of previous table hacks and all-image-based tabs. The Sliding Doors Technique Beautifully crafted, truly flexible interface components which expand and contract with the size of the text can be created if we use two separate background images. Think of these two images as Sliding Doors that complete one doorway. The doors slide together and overlap more to fill a narrow space, or slide apart and overlap less to fill a wider space, as the diagram below shows: With this model, one image covers up a portion of the other. Assuming we have something unique on the outside of each image, like the rounded-corner of a tab, we dont want the image in front to completely obscure the image behind it. To prevent this from happening, we make the image in front left-side for this example as narrow as possible. If the outside corners are rounded, we should make the front image only as wide as the curved portion of the image: If the object grows any larger than the width shown above, due to differing text or type size changes, the images will get pulled apart, creating an ugly gap. We need to make an arbitrary judgment about the amount of expansion well accommodate. How large do we think the object might grow as text is resized in the browser? Realistically, we should account for the possibility of our tab text increasing by at least 300. We need to expand the background images to compensate for that growth. For these examples well make the back image right-side 400x150 pixels, and the front image 9x150 pixels. Keep in mind that background images only show in the available doorway of the element to which theyre applied content area padding. The two images are anchored to the outside corners of their respective elements. For one of the tabs, the fill was lightened and the border darkened the lighter version will be used to represent the current tab. Given this techniques model for left and right tab images, we need to expand coverage area of the tab image, and cut it into two pieces: The same thing needs to happen with the lighter current tab image. Once we have all four images created, 1 , 2 , 3 , 4 we can jump into the markup and CSS for our tabs. Tab Creation As you explore the creation of horizontal lists with CSS, youll notice at least two methods for arranging a group of items into one row. Both require dealing with rather funky aspects of CSS which quickly become confusing. The First Method and possibly the more common is to change the display of each list item to inline . However, the inline method causes a few rendering problems in certain browsers for the Sliding Doors technique were going to discuss. The Second Method , which is the one well focus on, uses floats to place each list item in a horizontal row. Their seemingly inconsistent behavior circumvents all natural logic. Still, a basic understanding of how to deal with multiple floated elements, and the means to reliably break out of floats or contain them can achieve wonders. Were going to nest several floated elements within another containing floated element. We do this so that the outer parent float completely wraps around the floats inside. This way, were able to add a background color and/or image behind our tabs. Its important to remember that the next element following our tabs needs to reset its own position by using the CSS clear property. This prevents the floated tabs from affecting the position of other page elements. Lets begin with the following markup: <div idheader> <ul> <li><a href>Home</a></li> <li idcurrent><a href>News</a></li> <li><a href>Products</a></li> <li><a href>About</a></li> <li><a href>Contact</a></li> </ul> </div> In reality, the header div might also contain a logo and a search box. Obviously, these values would normally contain file or directory locations. This helps ensure the container actually contains the list items inside which will also be floated. Since the element is floated, we also need to assign it a width of 100. A temporary yellow background is added to ensure this parent stretches to fill the entire area behind the tabs. We also set some default text properties, ensuring everything inside will be the same: header float:left;
Finishing Touches Keen eyes may have noticed white tab corners showing up in the previous example. These opaque corners are currently preventing the image in the back from showing through the left corner of the image in front. In theory, we could attempt to match the corners of the tab images with a portion of the background behind them. But our tabs can grow in height, which pushes the background behind them lower, shifting the background color we tried to match. Instead, we change the images, making the corners of our tabs transparent. If the curves are anti-aliased, we matte the edges to an average of the background color behind them. Now that the corners are transparent, a piece of the right-side image shows through the corner of the left-side image. To compensate for this, we add a small amount of left padding to the list item equivalent to the width of the left-side image 9px. Since padding was added to the list item, we need to remove that same amount from the anchor to keep the text centered 15px - 9px 6px: header li float:left;
We see all additions and changes so far represented in Example 5 . One Hack for Consistency After Example 2, we acknowledged a problem with IE5/Mac where each tab stretched across the entire browser width, forcing each one to stack vertically on top of each other. In most browsers, floating an element will act sort of like shrink-wrapping it it gets shrunk to the smallest possible size of the contents it contains. If a floated element contains or is an image, the float will shrink to the width of the image. If it contains only text, the float will shrink to the width of the longest non-wrapping line of text. A problem enters the picture for IE5/Mac when an auto-width block-level element is inserted into a floated element. Other browsers still shrink the float as small as possible, regardless of the block-level element it contains. Instead, it expands the float and block-level element to full available width. To work around this problem, we need to float the anchor also, but only for IE5/Mac, ...
|