开发者

Styling button background-image, button icon image, and text using CSS sprites

开发者 https://www.devze.com 2023-01-04 15:21 出处:网络
I\'m trying to elegantly solve a styling issue with some buttons and images. My goal is开发者_开发知识库 to have buttons that look like the following:

I'm trying to elegantly solve a styling issue with some buttons and images. My goal is开发者_开发知识库 to have buttons that look like the following:

(Hacky mspaint mockup)

Styling button background-image, button icon image, and text using CSS sprites

(source: robhruska.com)

However, I have a set of criteria I'd like to meet:

  • I also need to be able to have the icon image exist as a button alone, with no text (i.e. the button background is the icon image and the button width/height = icon image width/height).
  • The icon-only button needs to support :hover states that change the background icon.
  • The text buttons need to support the gradient background changing on :hover, but the icon itself does not have to change.

I have both the icon image and gradient image available to me in a vertical CSS sprite image.

Currently, I can only think to do this with separate sets of styles for the text buttons and icon-only buttons, along the lines of:

<!-- text-button -->
<!--   button.text-button would have gradient background and border -->
<!--   button.text-button:hover would change to the hover gradient -->
<!--   .icon would have the icon background (icon border is included in image) -->
<button class="text-button">
    <div class="icon-delete">Button Text</div>
</button>

<!-- icon-only button -->
<!--   button.icon-button would have the specific icon image background -->
<!--   button.icon-button:hover would change to the hover state background -->
<!--   button styling is different than .text-button, since icon border is included in image -->
<button class="icon-button-delete"></button>

I don't particularly like using the inner <div> for the text button, since it seems to add more markup that might be unnecessary. It also makes it so that if I wanted to go back later and add text to a button, I'd have to change several components instead of just changing the button class. It also means that I probably have to define the image positions for my icon sprites for several different combinations of button/div styles, which isn't DRY.

To summarize my question: How can I do this with a single top-level style on the <button>, rather than using nested elements or separate styles for the icon- vs text- buttons? It doesn't necessarily have to be a <button> either, it could be any element if it accomplishes this elegantly.

I don't really need a full code sample, just a suggestion for how it might be accomplished best.


You can reduce the markup a bit:

<div class="button">
    <a class="yourIcon">Button Text</a>
</div>

.button gets the gradient image.

.yourIcon can then get an icon for a background if desired.


Personally, I'd just use an <img> with a transparent gif and a CSS background-image instead of your icon div. And a span for the text. For the text-free version of the button, just leave out the span and adjust the button class.

I've built a crude demonstration here: http://jsfiddle.net/TTyPZ/3/

Version 2: http://jsfiddle.net/z9pD9/1/


You could use simplify it at max: just use gradient as background and insert insert another tag with icon as background inside, use css vertical-align property (it accepts % values) to place the icon properly aligned to text.

instead of using div tags consider using <b> tag, ir saves ytou some bytes and it is s google technique by the way.

hope this helps


Can you just create 2 separate button elements and use absolute positioning to get the icon button on top of the big button?

0

精彩评论

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