原文:
1. CSS Resets
01
|
html, body, div, span, applet, object, iframe, h1, h2, h3, h4, h5, h6, p, blockquote, pre, a, abbr, acronym, address, big, cite, code, del, dfn, em, img, ins, kbd, q, s, samp, small, strike, strong, sub, sup, tt, var, b, u, i, center, dl, dt, dd, ol, ul, li, fieldset, form, label, legend, table, caption, tbody, tfoot, thead, tr, th, td, article, aside, canvas, details, embed, figure, figcaption, footer, header, hgroup, menu, nav, output, ruby, section, summary, time, mark, audio, video {
|
07
|
vertical-align: baseline;
|
09
|
-webkit-box-sizing: border-box;
|
10
|
-moz-box-sizing: border-box;
|
11
|
box-sizing: border-box;
|
13
|
html { height: 101%; }
|
14
|
body { font-size: 62.5%; line-height: 1; font-family: Arial, Tahoma, sans-serif; }
|
16
|
article, aside, details, figcaption, figure, footer, header, hgroup, menu, nav, section { display: block; }
|
17
|
ol, ul { list-style: none; }
|
19
|
blockquote, q { quotes: none; }
|
20
|
blockquote:before, blockquote:after, q:before, q:after { content: ''; content: none; }
|
21
|
strong { font-weight: bold; }
|
23
|
table { border-collapse: collapse; border-spacing: 0; }
|
24
|
img { border: 0; max-width: 100%; }
|
26
|
p { font-size: 1.2em; line-height: 1.0em; color: #333; }
|
Basic
CSS browser resets are some of the most common snippets you’ll find
online. This is a customized snippet by myself which is based off . I have included a bit for responsive images and set all core elements to border-box, keeping margins and padding measurements aligned properly.
2. Classic CSS Clearfix
1
|
.clearfix:after { content: "."; display: block; clear: both; visibility: hidden; line-height: 0; height: 0; }
|
2
|
.clearfix { display: inline-block; }
|
4
|
html[xmlns] .clearfix { display: block; }
|
5
|
* html .clearfix { height: 1%; }
|
This
clearfix code has been around the Web for years circulating amongst
savvy web developers. You should apply this class onto a container which
holds floating elements. This will ensure any content which comes
afterwards will not float but instead be pushed down and cleared.
3. 2011 Updated Clearfix
1
|
.clearfix:before, .container:after { content: ""; display: table; }
|
2
|
.clearfix:after { clear: both; }
|
From
what I can tell there isn’t a major difference in rendering between
this newer version and the classic version. Both of these classes will
effectively clear your floats, and they should work in all modern
browsers and even legacy Internet Explorer 6-8.
4. Cross-Browser Transparency
2
|
filter: alpha(opacity=50); /* internet explorer */
|
3
|
-khtml-opacity: 0.5; /* khtml, old safari */
|
4
|
-moz-opacity: 0.5; /* mozilla, netscape */
|
5
|
opacity: 0.5; /* fx, safari, opera */
|
Some of the newer CSS3 properties have pampered us into thinking they
may be applied everywhere. Unfortunately opacity is one such example
where CSS still requires some minor updates. Appending the filter property should handle any older versions of IE with grace.
5. CSS Blockquote Template
03
|
border-left: 10px solid #ccc;
|
06
|
quotes: "\201C""\201D""\2018""\2019";
|
14
|
vertical-align: -.4em;
|
Not everybody needs to use blockquotes inside their website. But I feel these are an excellent HTML element for separating quoted or repeated content within blogs or webpages. This basic chunk of CSS offers a default style for your blockquotes so they don’t appear as drab and bland.
6. Individual Rounded Corners
02
|
-webkit-border-radius: 4px 3px 6px 10px;
|
03
|
-moz-border-radius: 4px 3px 6px 10px;
|
04
|
-o-border-radius: 4px 3px 6px 10px;
|
05
|
border-radius: 4px 3px 6px 10px;
|
08
|
/* alternative syntax broken into each line */
|
10
|
-webkit-border-top-left-radius: 4px;
|
11
|
-webkit-border-top-right-radius: 3px;
|
12
|
-webkit-border-bottom-right-radius: 6px;
|
13
|
-webkit-border-bottom-left-radius: 10px;
|
15
|
-moz-border-radius-topleft: 4px;
|
16
|
-moz-border-radius-topright: 3px;
|
17
|
-moz-border-radius-bottomright: 6px;
|
18
|
-moz-border-radius-bottomleft: 10px;
|
Most developers are familiar with the CSS3 rounded corners syntax. But how would you go about setting different values for each of the corners?
Save this code snippet and you should never run into the problem again!
I’ve included both a condensed version and a longer base with each
corner radius broken down into a different property.
7. General Media Queries
01
|
/* Smartphones (portrait and landscape) ----------- */
|
03
|
and (min-device-width : 320px) and (max-device-width : 480px) {
|
07
|
/* Smartphones (landscape) ----------- */
|
08
|
@media only screen and (min-width : 321px) {
|
12
|
/* Smartphones (portrait) ----------- */
|
13
|
@media only screen and (max-width : 320px) {
|
17
|
/* iPads (portrait and landscape) ----------- */
|
18
|
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) {
|
22
|
/* iPads (landscape) ----------- */
|
23
|
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : landscape) {
|
27
|
/* iPads (portrait) ----------- */
|
28
|
@media only screen and (min-device-width : 768px) and (max-device-width : 1024px) and (orientation : portrait) {
|
32
|
/* Desktops and laptops ----------- */
|
33
|
@media only screen and (min-width : 1224px) {
|
37
|
/* Large screens ----------- */
|
38
|
@media only screen and (min-width : 1824px) {
|
42
|
/* iPhone 4 ----------- */
|
43
|
@media only screen and (-webkit-min-device-pixel-ratio:1.5), only screen and (min-device-pixel-ratio:1.5) {
|
Code Source
This is an excellent template which you can find on CSS-Tricks for other bits and pieces of media queries. However I’ve copied their
example in full which includes tons of real mobile devices. These codes
will even target retina-based devices using min-device-pixel-ratio.
8. Modern Font Stacks
01
|
/* Times New Roman-based serif */
|
02
|
font-family: Cambria, "Hoefler Text", Utopia, "Liberation Serif", "Nimbus Roman No9 L Regular", Times, "Times New Roman", serif;
|
04
|
/* A modern Georgia-based serif */
|
05
|
font-family: Constantia, "Lucida Bright", Lucidabright, "Lucida Serif", Lucida, "DejaVu Serif," "Bitstream Vera Serif", "Liberation Serif", Georgia, serif;
|
07
|
/*A more traditional Garamond-based serif */
|
08
|
font-family: "Palatino Linotype", Palatino, Palladio, "URW Palladio L", "Book Antiqua", Baskerville, "Bookman Old Style", "Bitstream Charter", "Nimbus Roman No9 L", Garamond, "Apple Garamond", "ITC Garamond Narrow", "New Century Schoolbook", "Century Schoolbook", "Century Schoolbook L", Georgia, serif;
|
10
|
/*The Helvetica/Arial-based sans serif */
|
11
|
font-family: Frutiger, "Frutiger Linotype", Univers, Calibri, "Gill Sans", "Gill Sans MT", "Myriad Pro", Myriad, "DejaVu Sans Condensed", "Liberation Sans", "Nimbus Sans L", Tahoma, Geneva, "Helvetica Neue", Helvetica, Arial, sans-serif;
|
13
|
/*The Verdana-based sans serif */
|
14
|
font-family: Corbel, "Lucida Grande", "Lucida Sans Unicode", "Lucida Sans", "DejaVu Sans", "Bitstream Vera Sans", "Liberation Sans", Verdana, "Verdana Ref", sans-serif;
|
16
|
/*The Trebuchet-based sans serif */
|
17
|
font-family: "Segoe UI", Candara, "Bitstream Vera Sans", "DejaVu Sans", "Bitstream Vera Sans", "Trebuchet MS", Verdana, "Verdana Ref", sans-serif;
|
19
|
/*The heavier “Impact” sans serif */
|
20
|
font-family: Impact, Haettenschweiler, "Franklin Gothic Bold", Charcoal, "Helvetica Inserat", "Bitstream Vera Sans Bold", "Arial Black", sans-serif;
|
23
|
font-family: Consolas, "Andale Mono WT", "Andale Mono", "Lucida Console", "Lucida Sans Typewriter", "DejaVu Sans Mono", "Bitstream Vera Sans Mono", "Liberation Mono", "Nimbus Mono L", Monaco, "Courier New", Courier, monospace;
|
It is difficult brainstorming your own CSS font stacks for designing
new webpages. I hope this snippet may alleviate some torture and give
you a few templates for getting started. If you want to find more
examples check out which is one of my favorite resources.
9. Custom Text Selection
1
|
::selection { background: #e2eae2; }
|
2
|
::-moz-selection { background: #e2eae2; }
|
3
|
::-webkit-selection { background: #e2eae2; }
|
Some newer web browsers will allow you to define the highlight color on your webpage. This is set to light blue by default, but you can setup any color value which tickles your fancy. This snippet includes the typical ::selection target along with vendor prefixes for Webkit and Mozilla.
10. Hiding H1 Text for Logo
6
|
background: transparent url("images/logo.png") no-repeat scroll;
|
I first noticed this technique being implemented on the old . You can setup an H1 tag which also has your website’s name in plaintext for SEO purposes. But using CSS we can move this text so it isn’t visible, and replace it with a custom logo image.
11. Polaroid Image Border
02
|
background:#000; /*Change this to a background image or remove*/
|
04
|
border-width:6px 6px 20px 6px;
|
05
|
box-shadow:1px 1px 5px #333; /* Standard blur at 5px. Increase for more depth */
|
06
|
-webkit-box-shadow:1px 1px 5px #333;
|
07
|
-moz-box-shadow:1px 1px 5px #333;
|
08
|
height:200px; /*Set to height of your image or desired div*/
|
09
|
width:200px; /*Set to width of your image or desired div*/
|
Applying this basic snippet will allow you to implement .polaroid classes onto your images. This will create the old photo-style effect with a large white border and some slight box shadows. You’ll want to update the width/height values to match that of your image dimensions and website layout.
12. Anchor Link Pseudo Classes
1
|
a:link { color: blue; }
|
2
|
a:visited { color: purple; }
|
3
|
a:hover { color: red; }
|
4
|
a:active { color: yellow; }
|
Code Source
Most CSS developers know about the anchor link styles and :hover effects. But I wanted to include this small code snippet as a reference
for newcomers. These are the four default states for an anchor link,
and also a few other HTML elements. Keep this handy until you can
memorize some of the more obscure ones.
13. Fancy CSS3 Pull-Quotes
01
|
.has-pullquote:before {
|
07
|
content: attr(data-pullquote);
|
09
|
/* Pull out to the right, modular scale based margins. */
|
12
|
margin: 12px -140px 24px 36px;
|
14
|
/* Baseline correction */
|
18
|
/* Typography (30px line-height equals 25% incremental leading) */
|
23
|
.pullquote-adelle:before {
|
24
|
font-family: "adelle-1", "adelle-2";
|
29
|
.pullquote-helvetica:before {
|
30
|
font-family: "Helvetica Neue", Arial, sans-serif;
|
35
|
.pullquote-facit:before {
|
36
|
font-family: "facitweb-1", "facitweb-2", Helvetica, Arial, sans-serif;
|
Pull-quotes are different from blockquotes in that they appear off to
the side of your blog or news article. These often reference quoted
text from the article, and so they appear slightly different than
blockquotes. This default class has some basic properties along with 3
unique font families to choose from.
14. Fullscreen Backgrounds with CSS3
2
|
background: url('images/bg.jpg') no-repeat center center fixed;
|
3
|
-webkit-background-size: cover;
|
4
|
-moz-background-size: cover;
|
5
|
-o-background-size: cover;
|
6
|
background-size: cover;
|
Code Source
I should note that this code will not work properly in older browsers
which do not support CSS3 syntax. However if you’re looking for a quick
solution and don’t care about legacy support, this is the best chunk of
code you’ll find! Great for adding big photographs into the background of your website while keeping them resizable and fixed as you scroll.
15. Vertically Centered Content
4
|
vertical-align: middle;
|
Using the margin: 0 auto technique it is very easy to embed content
into the horizontal center of your page. However vertical content is a
lot harder, especially considering scrollbars and other methods. But
this is a pure CSS solution which should work flawlessly without
JavaScript.
16. Force Vertical Scrollbars
When
your page content doesn’t fill the entire height of your browser window
then you don’t end up getting any scrollbars. However resizing will
force them to appear and append an extra 10-15 pixels to the width of
your window, pushing over your webpage content. This snippet will ensure
your HTML element is always just a little bit higher than the browser which forces scrollbars to stay in place at all times.
17. CSS3 Gradients Template
3
|
background-image: -webkit-gradient(linear, left top, left bottom, from(#83b842), to(#629721));
|
4
|
background-image: -webkit-linear-gradient(top, #83b842, #629721);
|
5
|
background-image: -moz-linear-gradient(top, #83b842, #629721);
|
6
|
background-image: -ms-linear-gradient(top, #83b842, #629721);
|
7
|
background-image: -o-linear-gradient(top, #83b842, #629721);
|
8
|
background-image: linear-gradient(top, #83b842, #629721);
|
CSS3
gradients are another wondrous part of the newer specifications. Many
of the vendor prefixes are difficult to memorize, so this code snippet
should save you a bit of time on each project.
18. @font-face Template
02
|
font-family: 'MyWebFont';
|
03
|
src: url('webfont.eot'); /* IE9 Compat Modes */
|
04
|
src: url('webfont.eot?#iefix') format('embedded-opentype'), /* IE6-IE8 */
|
05
|
url('webfont.woff') format('woff'), /* Modern Browsers */
|
06
|
url('webfont.ttf') format('truetype'), /* Safari, Android, iOS */
|
07
|
url('webfont.svg#svgFontName') format('svg'); /* Legacy iOS */
|
11
|
font-family: 'MyWebFont', Arial, sans-serif;
|
Here is another bit of CSS3 code which isn’t the easiest to memorize.
Using @font-face you may embed your own TTF/OTF/SVG/WOFF files into
your website and generate custom font families. Use this template as a
base example for your own projects in the future.
19. Stitched CSS3 Elements
10
|
-webkit-box-shadow: 0 0 0 4px #ff0030, 2px 1px 4px 4px rgba(10,10,0,.5);
|
11
|
-moz-box-shadow: 0 0 0 4px #ff0030, 2px 1px 4px 4px rgba(10,10,0,.5);
|
12
|
box-shadow: 0 0 0 4px #ff0030, 2px 1px 6px 4px rgba(10,10,0,.5);
|
13
|
-webkit-border-radius: 3px;
|
14
|
-moz-border-radius: 3px;
|
26
|
border: 2px dashed #fff;
|
34
|
p a:hover, p a:focus, p a:active {
|
35
|
text-decoration:underline;
|
20. CSS3 Zebra Stripes
1
|
tbody tr:nth-child(odd) {
|
2
|
background-color: #ccc;
|
Possibly the best item to include zebra stripes is within a table of
data. It can be difficult when users are scanning 40 or 50 rows to
determine exactly which cell is lined up to which row. By adding zebra
stripes on default we can update odd rows with varying background
colors.
21. Fancy Ampersand
2
|
font-family: Baskerville, 'Goudy Old Style', Palatino, 'Book Antiqua', serif;
|
This class would be applied to one span element wrapped around your
ampersand character in page content. It will apply some classic serif
fonts and use italics to enhance the ampersand symbol. Try it out on a
demo webpage and see how you like the design.
22. Drop-Cap Paragraphs
7
|
font-family: Georgia, Times New Roman, serif;
|
Typically
you’ll notice dropped capitals appear in printed mediums, such as
newspapers and books. However this can also be a neat effect in webpages
or blogs where there is enough extra room in the layout. This CSS rule
is targeting all paragraphs but you may limit this based on a single
class or ID.
23. Inner CSS3 Box Shadow
2
|
-moz-box-shadow: inset 2px 0 4px #000;
|
3
|
-webkit-box-shadow: inset 2px 0 4px #000;
|
4
|
box-shadow: inset 2px 0 4px #000;
|
The
box shadow property has offered immense changes into how we build
websites. You can portray box shadows on nearly any element, and they
all generally look great. This piece of code will force inner shadows
which is a lot harder to design around, but in the right cases it looks
pristine.
24. Outer CSS3 Box Shadow
2
|
-webkit-box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
|
3
|
-moz-box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
|
4
|
box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
|
In
relation to the inner CSS3 shadows I also want to present an outer
shadow code snippet. Note the 3rd number in our syntax represents blur
distance while the 4th number represents the spread. You can learn more
about these values from .
25. Triangular List Bullets
08
|
border-color: transparent #111;
|
10
|
border-width: 0.35em 0 0.35em 0.45em;
|
Believe it or not it is actually possible to generate triangle-shaped bullets solely in CSS3.
This is a really cool technique which does look awesome in respected
browsers. The only potential issue is a major lack of support for
fallback methods.
26. Centered Layout Fixed Width
I know earlier it was mentioned how to setup horizontal positioning. I want to jump back in with this quick snippet for horizontal positioning, which is perfect to be used on fixed-width layouts.
27. CSS3 Column Text
5
|
-moz-column-rule: 1px solid #c4c8cc;
|
6
|
-webkit-column-count: 3;
|
7
|
-webkit-column-gap: 12px;
|
8
|
-webkit-column-rule: 1px solid #c4c8cc;
|
Code Source
CSS3 columns would be nice to see in website layouts, but the reality
is how we can split up text based on column styles. Use this snippet to
place any number of columns inline with your paragraphs, where text
will split evenly based on your column number.
28. CSS Fixed Footer
13
|
top: expression((0-(footer.offsetHeight)+(document.documentElement.clientHeight
? document.documentElement.clientHeight :
document.body.clientHeight)+(ignoreMe =
document.documentElement.scrollTop ? document.documentElement.scrollTop :
document.body.scrollTop))+'px');
|
This is actually a lot more useful than it sounds, but appending a
fixed footer into your website is quite simple. These footers will
scroll with the user and may contain helpful information about your site
or unique contact details. Ideally this would only be implemented in
cases where it truly adds value to the user interface.
29. Transparent PNG Fix for IE6
04
|
background: url(/folder/yourimage.png) no-repeat;
|
06
|
_filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='/folder/yourimage.png',sizingMethod='crop');
|
13
|
behavior: expression((this.runtimeStyle.behavior="none")&&(this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none",
|
14
|
this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "', sizingMethod='image')",
|
15
|
this.src = "images/transparent.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''),
|
16
|
this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "', sizingMethod='crop')",
|
17
|
this.runtimeStyle.backgroundImage = "none")),this.pngSet=true));
|
Using transparent images inside websites has become a very common
practice. This started with gif images, but has evolved into
alpha-transparent PNGs. Unfortunately older legacy versions of Internet
Explorer have never supported the transparency. Adding this brief CSS
snippet should clear up the problem.
30. Cross-Browser Minimum Height
3
|
height: auto !important;
|
Developers who have needed to work with min-height know all about the shady support. Many newer browsers can handle this
perfectly, however Internet Explorer and older versions of Firefox do
have trouble. This set of codes should provide a fix to any related
bugs.
31. CSS3 Glowing Inputs
01
|
input[type=text], textarea {
|
02
|
-webkit-transition: all 0.30s ease-in-out;
|
03
|
-moz-transition: all 0.30s ease-in-out;
|
04
|
-ms-transition: all 0.30s ease-in-out;
|
05
|
-o-transition: all 0.30s ease-in-out;
|
07
|
padding: 3px 0px 3px 3px;
|
08
|
margin: 5px 1px 3px 0px;
|
09
|
border: 1px solid #ddd;
|
12
|
input[type=text]:focus, textarea:focus {
|
13
|
box-shadow: 0 0 5px rgba(81, 203, 238, 1);
|
14
|
padding: 3px 0px 3px 3px;
|
15
|
margin: 5px 1px 3px 0px;
|
16
|
border: 1px solid rgba(81, 203, 238, 1);
|
I really enjoy this basic custom CSS3 class because of how it
overwrites the default browser behavior. Users of Chrome & Safari
know about annoying input outlines in forms. Adding these properties
into your stylesheet will setup a whole new design for basic input
elements.
32. Style Links Based on Filetype
04
|
background: url('external.gif') no-repeat center right;
|
10
|
background: url('email.png') no-repeat center right;
|
16
|
background: url('acrobat.png') no-repeat center right;
|
Code Source
Quite the obscure bit of CSS but I love the creativity! You can
determine the file type of your links using CSS selectors and implement
icons as background images. These may include the various protocols
(HTTP, FTP, IRC, mailto) or simply the file types themselves (mp3, avi,
pdf).
33. Force Code Wraps
2
|
white-space: pre-wrap; /* css-3 */
|
3
|
white-space: -moz-pre-wrap; /* Mozilla, since 1999 */
|
4
|
white-space: -pre-wrap; /* Opera 4-6 */
|
5
|
white-space: -o-pre-wrap; /* Opera 7 */
|
6
|
word-wrap: break-word; /* Internet Explorer 5.5+ */
|
The typical pre tags are used in layouts to display large chunks of
code. This is preformatted text like you would find inside Notepad or
Textedit, except you’ll often notice long lines produce horizontal
scrollbars. This block of CSS will force all pre tags to wrap code instead of breaking outside the container.
34. Force Hand Cursor over Clickable Items
1
|
a[href], input[type='submit'], input[type='image'], label[for], select, button, .pointer {
|
Code Source
There are lots of default clickable HTML elements which do not always
display the hand pointer icon. Using this set of CSS selectors you may
force the pointer over a number of key elements, along with any other
objects using the class .pointer.
35. Webpage Top Box Shadow
09
|
-webkit-box-shadow: 0px 0px 10px rgba(0,0,0,.8);
|
10
|
-moz-box-shadow: 0px 0px 10px rgba(0,0,0,.8);
|
11
|
box-shadow: 0px 0px 10px rgba(0,0,0,.8);
|
Developers may not find a great use for this other than some pleasing
aesthetics. But I really enjoy this effect and it’s definitely
something unique! Simply append this CSS code targeting your body
element to display a dark drop shadow fading down from the top of your webpage.
36. CSS3 Speech Bubble
02
|
background-color: #ededed;
|
03
|
border: 2px solid #666;
|
11
|
-moz-border-radius: 20px;
|
12
|
-webkit-border-radius: 20px;
|
13
|
-moz-box-shadow: 0 0 5px #888;
|
14
|
-webkit-box-shadow: 0 0 5px #888;
|
15
|
font-family: 'Bangers', arial, serif;
|
17
|
.chat-bubble-arrow-border {
|
18
|
border-color: #666 transparent transparent transparent;
|
28
|
border-color: #ededed transparent transparent transparent;
|
Numerous user interface purposes come to mind when discussing speech
bubbles. These could be handy in discussion comments, or creating
bulletin boards, or displaying quoted text. Simply add the following
classes into your stylesheet and you can find related HTML codes from .
37. Default H1-H5 Headers
I have offered lots of common syntax including browser CSS resets and a few HTML element resets. This template includes default styles for all major heading elements ranging from H1-H5. You may also consider adding H6 but I have never seen a website using all six nested headers.
38. Pure CSS Background Noise
2
|
background-image: url();
|
3
|
background-color: #0094d0;
|
Designers have seen this effect added into websites for a long time,
although they generally use repeating tile images with
alpha-transparency. However we can embed Base64 code into CSS to
generate brand new images. This is the case as in the snippet above
which generates a small noise texture above the body background, or you can create a customized noise background over at .
39. Continued List Ordering
06
|
ol.chapters > li:before {
|
07
|
content: counter(chapter) ". ";
|
08
|
counter-increment: chapter;
|
19
|
counter-reset: chapter;
|
23
|
counter-reset: chapter 11;
|
I feel this may not be an extremely popular snippet, but it does have
its market among developers. There may be situations where you’ll need
to continue a list of items but split into two separate UL elements. Check out the code above for an awesome CSS-only fix.
40. CSS Tooltip Hovers
02
|
border-bottom:1px solid #bbb;
|
17
|
a[data-tooltip]:after {
|
18
|
border-top: 8px solid #222;
|
19
|
border-top: 8px solid hsla(0,0%,0%,.85);
|
20
|
border-left: 8px solid transparent;
|
21
|
border-right: 8px solid transparent;
|
29
|
a[data-tooltip]:before {
|
31
|
background: hsla(0,0%,0%,.85);
|
33
|
content: attr(data-tooltip);
|
35
|
font-family: sans-serif;
|
42
|
text-shadow: 0 1px 1px hsla(0,0%,0%,1);
|
44
|
-webkit-border-radius: 5px;
|
45
|
-moz-border-radius: 5px;
|
46
|
-o-border-radius: 5px;
|
49
|
a[data-tooltip]:hover:after {
|
53
|
a[data-tooltip]:hover:before {
|
57
|
a[data-tooltip]:active:after {
|
60
|
a[data-tooltip]:active:before {
|
There are lots of open source jQuery-based tooltips which you can
implement on your websites. But CSS-based tooltips are very rare, and
this is one of my favorite snippets. Just copy this over into your
stylesheet and using the new HTML5 data-attributes you can setup the tooltip text via data-tooltip.
41. Dark Grey Rounded Buttons
02
|
-moz-box-shadow:inset 0px 1px 0px 0px #ffffff;
|
03
|
-webkit-box-shadow:inset 0px 1px 0px 0px #ffffff;
|
04
|
box-shadow:inset 0px 1px 0px 0px #ffffff;
|
05
|
background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #d1d1d1) );
|
06
|
background:-moz-linear-gradient( center top, #ffffff 5%, #d1d1d1 100% );
|
07
|
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#d1d1d1');
|
08
|
background-color:#ffffff;
|
09
|
-moz-border-radius:6px;
|
10
|
-webkit-border-radius:6px;
|
12
|
border:1px solid #dcdcdc;
|
20
|
text-shadow:1px 1px 0px #ffffff;
|
23
|
background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #d1d1d1), color-stop(1, #ffffff) );
|
24
|
background:-moz-linear-gradient( center top, #d1d1d1 5%, #ffffff 100% );
|
25
|
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#d1d1d1', endColorstr='#ffffff');
|
26
|
background-color:#d1d1d1;
|
As another helpful template for web developers I have included this simplistic CSS3 buttons class. I am using the class name .graybtn which is appropriate for the colors, but this isn’t to say you couldn’t
change the styles to match your own website. Check out the hex values
inside a color wheel to match similar hues in different color ranges.
42. Display URLS in a Printed Webpage
3
|
content: " [" attr(href) "] ";
|
If you run a news website or resource with lots of print material,
this is possibly one of the greatest snippets you’ll ever find. Anchor
links in your webpage will look and display exactly as normal. However
when printed your users will be able to see the link text along with the
full hyperlinked URL. This is handy when visitors need to access a
webpage you’ve linked but cannot see the URL in a typical printed document.
43. Disable Mobile Webkit Highlights
2
|
-webkit-touch-callout: none;
|
3
|
-webkit-user-select: none;
|
4
|
-khtml-user-select: none;
|
5
|
-moz-user-select: none;
|
Depending
on your experience working in mobile this snippet may not appear very
helpful. But when accessing mobile websites in Safari and other
Webkit-based engines, you’ll notice a grey box surrounds elements as you
tap them. Just append these styles into your website and it should remove all native mobile browser highlights.
44. CSS3 Polka-Dot Pattern
2
|
background: radial-gradient(circle, white 10%, transparent 10%),
|
3
|
radial-gradient(circle, white 10%, black 10%) 50px 50px;
|
4
|
background-size: 100px 100px;
|
I was a bit taken back when initially finding this snippet online.
But it is a really interesting method for generating CSS3-only BG
patterns on the fly. I have targeted the body element as default but you
could apply this onto any container div in your webpage.
45. CSS3 Checkered Pattern
2
|
background-color: white;
|
3
|
background-image: linear-gradient(45deg, black 25%, transparent 25%, transparent 75%, black 75%, black),
|
4
|
linear-gradient(45deg, black 25%, transparent 25%, transparent 75%, black 75%, black);
|
5
|
background-size: 100px 100px;
|
6
|
background-position: 0 0, 50px 50px;
|
Similar to the polka-dots above we can also create a full seamless
checkerboard pattern. This method requires a bit more syntax to get
working, but it looks flawless in all CSS3-supported browsers. Also you
can change the color values from white and black to match that of your
own website color scheme.
46. Github Fork Ribbon
02
|
background-color: #a00;
|
08
|
/* 45 deg ccw rotation */
|
09
|
-moz-transform: rotate(-45deg);
|
10
|
-webkit-transform: rotate(-45deg);
|
12
|
-moz-box-shadow: 0 0 1em #888;
|
13
|
-webkit-box-shadow: 0 0 1em #888;
|
16
|
border: 1px solid #faa;
|
19
|
font: bold 81.25% 'Helvetiva Neue', Helvetica, Arial, sans-serif;
|
20
|
margin: 0.05em 0 0.075em 0;
|
23
|
text-decoration: none;
|
25
|
text-shadow: 0 0 0.5em #444;
|
As a big user on Github this basic code snippet blew my mind. You can
quickly generate Github corner ribbons in your webpage using CSS3
transform properties. This is perfect for open source plugins or code
packs which have a popular following on Github. Also great for hosted
HTML/CSS/JS demos if you have an active Github repo.
47. Condensed CSS Font Properties
2
|
font: italic small-caps bold 1.2em/1.0em Arial, Tahoma, Helvetica;
|
The main reason web developers don’t always use this condensed font
property is because not every setting is needed. But having an
understanding of this shorthand may save you a lot of time and space in
your stylesheets. Keep this snippet handy just in case you ever want to
shorten the formatting of your font styles.
48. Paper Page Curl Effect
03
|
z-index: 1; /* prevent shadows falling behind containers with backgrounds */
|
16
|
border: 1px solid #efefef;
|
17
|
margin: 0 30px 30px 0;
|
19
|
-webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
|
20
|
-moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
|
21
|
box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
|
32
|
max-width: 300px; /* avoid rotation causing ugly appearance at large container widths */
|
35
|
-webkit-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
|
36
|
-moz-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
|
37
|
box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
|
38
|
-webkit-transform: skew(-15deg) rotate(-6deg);
|
39
|
-moz-transform: skew(-15deg) rotate(-6deg);
|
40
|
-ms-transform: skew(-15deg) rotate(-6deg);
|
41
|
-o-transform: skew(-15deg) rotate(-6deg);
|
42
|
transform: skew(-15deg) rotate(-6deg);
|
48
|
-webkit-transform: skew(15deg) rotate(6deg);
|
49
|
-moz-transform: skew(15deg) rotate(6deg);
|
50
|
-ms-transform: skew(15deg) rotate(6deg);
|
51
|
-o-transform: skew(15deg) rotate(6deg);
|
52
|
transform: skew(15deg) rotate(6deg);
|
This page curl effect can be applied to almost any container which
holds website content. Immediately I thought about image media and
quoted text, but really this could be anything at all. Check out the
snippet’s for a better grasp of how these page curls function.
49. Glowing Anchor Links
16
|
a, a:visited, a:active {
|
17
|
text-decoration: none;
|
19
|
-webkit-transition: all .3s ease-in-out;
|
23
|
text-shadow: 0 0 10px #ff0;
|
CSS3 text shadows offer a unique method of styling your webpage
typography. And more specifically this snippet is an excellent resource
for custom creative links with glowing hover effects. I
doubt this effect can be pulled off elegantly in the majority of
websites, but if you have the patience to get it looking nice you are
sure to impress visitors.
50. Featured CSS3 Display Banner
05
|
.featureBanner:before {
|
14
|
border: 15px solid #ffa200;
|
15
|
border-right-color: transparent;
|
17
|
box-shadow: -0px 5px 5px -5px #000;
|
21
|
.featureBanner:after {
|
26
|
border: 4px solid #89540c;
|
27
|
border-left-color: transparent;
|
28
|
border-bottom-color: transparent;
|
Generally you would need to setup a background image to duplicate
this effect in other browsers. But in CSS3-supported engines we can
generate dynamic banners which hang off the edge of your content wrappers, all without images!
These may look good attached onto e-commerce products, image
thumbnails, video previews, or blog articles, to list just a few ideas.