Web開發者的福利 30段超實用CSS程式碼

csdn發表於2013-05-30

  Web開發者的福利30段超實用CSS程式碼。上週,發表了一篇《Web開發者不容錯過的20段CSS程式碼》,大家一致覺得很實用。該文是筆者對後30個的翻譯,希望對大家有幫助。

  1.花式連字元(&)

  這個類應該在span元素裡使用,並且裡面包括&字元。它使用經典的serif字型和斜體來增強&符號。

.amp {
    font-family: Baskerville, 'Goudy Old Style', Palatino, 'Book Antiqua', serif;
    font-style: italic;
    font-weight: normal;
}

  原始碼地址: http://css-tricks.com/snippets/css/fancy-ampersand/

  2.段落首字元下沉

  通常,這種效果會出現在印刷媒體上,如報紙或書籍。同樣,如果網頁佈局合理,它也可以使用在Web頁面上,它僅針對段落使用,但你也可以與單個元素繫結。

p:first-letter{
    display: block;
    margin: 5px 0 0 5px;
    float: left;
    color: #ff3366;
    font-size: 5.4em;
    font-family: Georgia, Times New Roman, serif;
}

  3.內層CSS3盒陰影

  盒陰影(box shadow)屬性幾乎可以運用在任何元素上,它們看起來都非常好看。下面這段程式碼主要聚焦內層陰影的設計。

#mydiv { 
    -moz-box-shadow: inset 2px 0 4px #000;
    -webkit-box-shadow: inset 2px 0 4px #000;
    box-shadow: inset 2px 0 4px #000;
}

  4.外層CSS3盒陰影

  下面介紹一段外層陰影程式碼設計,注意,程式碼裡的第三個參數列示模糊距離(blur distance),而第四個參數列示鋪開的(spread)距離。關於這些值的設計,你可以前往 W3Schools學習。

#mydiv { 
    -webkit-box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
    -moz-box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
    box-shadow: 0 2px 2px -2px rgba(0, 0, 0, 0.52);
}

  5.三角形列表符號

  該符號只能在CSS3裡生成,在主流瀏覽器中,這是一項非常酷的技術。而其唯一的潛在問題是缺乏對後退方法的支援。 

ul {
    margin: 0.75em 0;
    padding: 0 1em;
    list-style: none;
}
li:before { 
    content: "";
    border-color: transparent #111;
    border-style: solid;
    border-width: 0.35em 0 0.35em 0.45em;
    display: block;
    height: 0;
    width: 0;
    left: -1em;
    top: 0.9em;
    position: relative;
}

  原始碼地址: http://jsfiddle.net/chriscoyier/yNZTU/

  6.居中對齊並設定固定寬度

#page-wrap {
    width: 800px;
    margin: 0 auto;
}

  原始碼地址: http://css-tricks.com/snippets/css/centering-a-website/

  7.CSS3列文字

#columns-3 {
    text-align: justify;
    -moz-column-count: 3;
    -moz-column-gap: 12px;
    -moz-column-rule: 1px solid #c4c8cc;
    -webkit-column-count: 3;
    -webkit-column-gap: 12px;
    -webkit-column-rule: 1px solid #c4c8cc;
}

  原始碼地址: http://www.djavupixel.com/development/css-development/master-css3-ultimate-css-code-snippets/

  8.固定頁尾

  在網頁裡新增固定的頁尾其實非常簡單,並且也很實用。有些網站的頁尾設計得很漂亮,可以給網站呈現出一個完美的結尾。

#footer {
    position: fixed;
    left: 0px;
    bottom: 0px;
    height: 30px;
    width: 100%;
    background: #444;
}
/* IE 6 */
* html #footer {
    position: absolute;
    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');
}

  原始碼地址: http://www.flashjunior.ch/school/footers/fixed.cfm

  9.IE 6下修復PNG格式的透明度

  在網站裡使用透明的影象已成為一種很普遍的做法,其始於.gif圖片格式,但現在也涉及到.png圖片格式。而一些老版本的IE不支援透明度,下面這段程式碼會很好地解決這一問題。

.bg {
    width:200px;
    height:100px;
    background: url(/folder/yourimage.png) no-repeat;
    _background:none;
    _filter:progid:DXImageTransform.Microsoft.AlphaImageLoader(src='/folder/yourimage.png',sizingMethod='crop');
}
/* 1px gif method */
img, .png {
    position: relative;
    behavior: expression((this.runtimeStyle.behavior="none")&&(this.pngSet?this.pngSet=true:(this.nodeName == "IMG" && this.src.toLowerCase().indexOf('.png')>-1?(this.runtimeStyle.backgroundImage = "none",
       this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.src + "', sizingMethod='image')",
       this.src = "images/transparent.gif"):(this.origBg = this.origBg? this.origBg :this.currentStyle.backgroundImage.toString().replace('url("','').replace('")',''),
       this.runtimeStyle.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(src='" + this.origBg + "', sizingMethod='crop')",
       this.runtimeStyle.backgroundImage = "none")),this.pngSet=true));
}

  原始碼地址: http://css-tricks.com/snippets/css/png-hack-for-ie-6/

  10.跨瀏覽器設定最小高度

  有時開發者需要對HTML元素設定最小高度,然而,這個效果卻無法相容IE和老版本的Firefox,下面這段程式碼可以修復這個問題。

#container {
    min-height: 550px;
    height: auto !important;
    height: 550px;
}
 

  11. CSS3發光輸入框

  下面的這段程式碼重寫了瀏覽器的預設行為,可以讓Chrome和Safari瀏覽器下普通的表單輸入框產生髮光效果。

input[type=text], textarea {
    -webkit-transition: all 0.30s ease-in-out;
    -moz-transition: all 0.30s ease-in-out;
    -ms-transition: all 0.30s ease-in-out;
    -o-transition: all 0.30s ease-in-out;
    outline: none;
    padding: 3px 0px 3px 3px;
    margin: 5px 1px 3px 0px;
    border: 1px solid #ddd;
}
input[type=text]:focus, textarea:focus {
    box-shadow: 0 0 5px rgba(81, 203, 238, 1);
    padding: 3px 0px 3px 3px;
    margin: 5px 1px 3px 0px;
    border: 1px solid rgba(81, 203, 238, 1);
}

  原始碼地址: http://css-tricks.com/snippets/css/glowing-blue-input-highlights/

  12.基於檔案型別來建立連結樣式

  下面這段程式碼通過使用CSS選擇器和影象圖示來實現各種型別的連結樣式,可能會用到各種協議(HTTP、FTP、IRC,mailto),或者是檔案本身的型別(mp3、avi、pdf)。

/* external links */
a[href^="http://"] {
    padding-right: 13px;
    background: url('external.gif') no-repeat center right;
} 
/* emails */
a[href^="mailto:"] {
    padding-right: 20px;
    background: url('email.png') no-repeat center right;
}
/* pdfs */
a[href$=".pdf"] {
    padding-right: 18px;
    background: url('acrobat.png') no-repeat center right;
}

  原始碼地址: http://www.designyourway.net/blog/resources/31-css-code-snippets-to-make-you-a-better-coder/

  13.pre標籤封裝程式碼

  pre標籤常用來對程式碼進行佈局,可以解決因為行太多帶來的滾動條問題。下面這段程式碼就使用pre來封裝程式碼,讓內容直接顯示在頁面中。

pre {
    white-space: pre-wrap;       /* css-3 */
    white-space: -moz-pre-wrap;  /* Mozilla, since 1999 */
    white-space: -pre-wrap;      /* Opera 4-6 */
    white-space: -o-pre-wrap;    /* Opera 7 */
    word-wrap: break-word;       /* Internet Explorer 5.5+ */
}

  原始碼地址: http://css-tricks.com/snippets/css/make-pre-text-wrap/

  14.滑鼠指向時變成手型

  網頁中有許多item在點選時,滑鼠不會變成小手的形狀。這套CSS選擇器會強迫滑鼠越過一些關鍵元素和其他物件一起來使用.pointer這個類。

a[href], input[type='submit'], input[type='image'], label[for], select, button, .pointer {
    cursor: pointer;
}

  原始碼地址: http://css-tricks.com/snippets/css/give-clickable-elements-a-pointer-cursor/

  15.頁面頂部陰影

  簡單地把下面這段程式碼拷貝到頁面裡,它會在body元素之前產生黑色的,漸漸變淡的陰影。這種效果通常用來給一個文字框或網頁元素加陰影。

body:before {
    content: "";
    position: fixed;
    top: -10px;
    left: 0;
    width: 100%;
    height: 10px;
    -webkit-box-shadow: 0px 0px 10px rgba(0,0,0,.8);
    -moz-box-shadow: 0px 0px 10px rgba(0,0,0,.8);
    box-shadow: 0px 0px 10px rgba(0,0,0,.8);
    z-index: 100;
}

  原始碼地址: http://css-tricks.com/snippets/css/top-shadow/

  16.氣泡引用效果

  這種效果常出現在論壇、建立公告牌或者是文字引用上。你只需把下面這段程式碼拷貝到樣式表檔案即可。 這裡(需翻牆)提供了許多關於語音泡泡的程式碼片段和使用技巧,歡迎去圍觀。

.chat-bubble {
    background-color: #ededed;
    border: 2px solid #666;
    font-size: 35px;
    line-height: 1.3em;
    margin: 10px auto;
    padding: 10px;
    position: relative;
    text-align: center;
    width: 300px;
    -moz-border-radius: 20px;
    -webkit-border-radius: 20px;
    -moz-box-shadow: 0 0 5px #888;
    -webkit-box-shadow: 0 0 5px #888;
    font-family: 'Bangers', arial, serif; 
}
.chat-bubble-arrow-border {
    border-color: #666 transparent transparent transparent;
    border-style: solid;
    border-width: 20px;
    height: 0;
    width: 0;
    position: absolute;
    bottom: -42px;
    left: 30px;
}
.chat-bubble-arrow {
    border-color: #ededed transparent transparent transparent;
    border-style: solid;
    border-width: 20px;
    height: 0;
    width: 0;
    position: absolute;
    bottom: -39px;
    left: 30px;
}

  原始碼地址(需翻牆): http://html5snippets.com/snippets/35-css3-comic-bubble-using-triangle-trick

  17.指定標題樣式

  該模板提供了所有頭元素的主要樣式,從H1到H5。

h1,h2,h3,h4,h5{
	color: #005a9c;
}
h1{
	font-size: 2.6em;
	line-height: 2.45em;
}
h2{
	font-size: 2.1em;
	line-height: 1.9em;
}
h3{
	font-size: 1.8em;
	line-height: 1.65em;
}
h4{
	font-size: 1.65em;
	line-height: 1.4em;
}
h5{
	font-size: 1.4em;
	line-height: 1.25em;
}

  原始碼地址: https://snipt.net/freshmaker99/headers/

  18.利用CSS生成紋理圖案背景

  通過CSS來為背景圖片新增噪點,從而形成漂亮的紋理圖案。你可以使用 NoiseTextureGenerator生成器自定義噪點的紋理圖案。

body {
    background-image: url();
    background-color: #0094d0;
}

  19.List Ordering

  你可能會遇到這種列表情況,需要把這個列表拆分成兩個UL元素,你不妨看看下面這段程式碼。

ol.chapters {
    list-style: none;
    margin-left: 0;
}

ol.chapters > li:before {
    content: counter(chapter) ". ";
    counter-increment: chapter;
    font-weight: bold;
    float: left;
    width: 40px;
}

ol.chapters li {
    clear: left;
}

ol.start {
	counter-reset: chapter;
}

ol.continue {
	counter-reset: chapter 11;
}

  原始碼地址: http://timmychristensen.com/css-ordered-list-numbering-examples.html

  20.為文字新增懸停提示框

  把這段程式碼拷貝到樣式表中,使用新的HTML5資料屬性,通過使用data-tooltip你就可以給文字新增懸停提示框了。

a { 
    border-bottom:1px solid #bbb;
    color:#666;
    display:inline-block;
    position:relative;
    text-decoration:none;
}
a:hover,
a:focus {
    color:#36c;
}
a:active {
    top:1px; 
}
 
/* Tooltip styling */
a[data-tooltip]:after {
    border-top: 8px solid #222;
    border-top: 8px solid hsla(0,0%,0%,.85);
    border-left: 8px solid transparent;
    border-right: 8px solid transparent;
    content: "";
    display: none;
    height: 0;
    width: 0;
    left: 25%;
    position: absolute;
}
a[data-tooltip]:before {
    background: #222;
    background: hsla(0,0%,0%,.85);
    color: #f6f6f6;
    content: attr(data-tooltip);
    display: none;
    font-family: sans-serif;
    font-size: 14px;
    height: 32px;
    left: 0;
    line-height: 32px;
    padding: 0 15px;
    position: absolute;
    text-shadow: 0 1px 1px hsla(0,0%,0%,1);
    white-space: nowrap;
    -webkit-border-radius: 5px;
    -moz-border-radius: 5px;
    -o-border-radius: 5px;
    border-radius: 5px;
}
a[data-tooltip]:hover:after {
    display: block;
    top: -9px;
}
a[data-tooltip]:hover:before {
    display: block;
    top: -41px;
}
a[data-tooltip]:active:after {
    top: -10px;
}
a[data-tooltip]:active:before {
    top: -42px;
}

  原始碼地址: http://www.impressivewebs.com/pure-css-tool-tips/

 

  21.建立暗灰色的按鈕樣式

  下面這段程式碼建立了CSS3按鈕類,並根據按鈕顏色命名為.graybtn。當然你也可以根據自己的網站風格對顏色進行更改。

.graybtn {
    -moz-box-shadow:inset 0px 1px 0px 0px #ffffff;
    -webkit-box-shadow:inset 0px 1px 0px 0px #ffffff;
    box-shadow:inset 0px 1px 0px 0px #ffffff;
    background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #ffffff), color-stop(1, #d1d1d1) );
    background:-moz-linear-gradient( center top, #ffffff 5%, #d1d1d1 100% );
    filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffff', endColorstr='#d1d1d1');
    background-color:#ffffff;
    -moz-border-radius:6px;
    -webkit-border-radius:6px;
    border-radius:6px;
    border:1px solid #dcdcdc;
    display:inline-block;
    color:#777777;
    font-family:arial;
    font-size:15px;
    font-weight:bold;
    padding:6px 24px;
    text-decoration:none;
    text-shadow:1px 1px 0px #ffffff;
}
.graybtn:hover {
    background:-webkit-gradient( linear, left top, left bottom, color-stop(0.05, #d1d1d1), color-stop(1, #ffffff) );
    background:-moz-linear-gradient( center top, #d1d1d1 5%, #ffffff 100% );
    filter:progid:DXImageTransform.Microsoft.gradient(startColorstr='#d1d1d1', endColorstr='#ffffff');
    background-color:#d1d1d1;
}
.graybtn:active {
    position:relative;
    top:1px;
}

  原始碼地址: http://html5snippets.com/snippets/1-a-css-rounded-gray-button

  22.列印的頁面上顯示URL

  這條規則會使列印出來的頁面在超連結文字後面加上URL,URL會被放在一組括號裡面,前後各留一個空格。

@media print   {  
  a:after {  
    content: " [" attr(href) "] ";  
  }  
}

  原始碼地址: http://www.smipple.net/snippet/bramloquet/Print%20the%20url%20after%20your%20links

  23.遮蔽Webkit移動瀏覽器中元素高亮效果

  在訪問移動網站時,你會發現,在選中的元素周圍會出現一些灰色的框框,而下面這段程式碼即可遮蔽這種樣式。

body {
    -webkit-touch-callout: none;
    -webkit-user-select: none;
    -khtml-user-select: none;
    -moz-user-select: none;
    -ms-user-select: none;
    user-select: none;
}

  24.利用CSS生成小圓點圖案

  通過下面的程式碼,可以讓你的網站背景上產生一些小圓點裝飾圖案。預設情況下,它是使用在body元素上,但你也可以把它使用在網頁裡的其他容器上。

body {
    background: radial-gradient(circle, white 10%, transparent 10%),
    radial-gradient(circle, white 10%, black 10%) 50px 50px;
    background-size: 100px 100px;
}

  原始碼地址: http://dabblet.com/gist/1457668

  25.CSS3棋盤格效果

和上面的小圓點設計一樣,這個效果需要一些額外的語法才可以工作,它需要在支援CSS3的瀏覽器上執行,效果很豔麗。當然,你可以根據需要自定義顏色。

body {
    background-color: white;
    background-image: linear-gradient(45deg, black 25%, transparent 25%, transparent 75%, black 75%, black), 
    linear-gradient(45deg, black 25%, transparent 25%, transparent 75%, black 75%, black);
    background-size: 100px 100px;
    background-position: 0 0, 50px 50px;
}

  26.Github Fork紅絲帶

  下面這段程式碼是利用CSS3的transform屬性生成Fork me on Github紅絲帶效果。

.ribbon {
    background-color: #a00;
    overflow: hidden;
    /* top left corner */
    position: absolute;
    left: -3em;
    top: 2.5em;
    /* 45 deg ccw rotation */
    -moz-transform: rotate(-45deg);
    -webkit-transform: rotate(-45deg);
    /* shadow */
    -moz-box-shadow: 0 0 1em #888;
    -webkit-box-shadow: 0 0 1em #888;
}
.ribbon a {
    border: 1px solid #faa;
    color: #fff;
    display: block;
    font: bold 81.25% 'Helvetiva Neue', Helvetica, Arial, sans-serif;
    margin: 0.05em 0 0.075em 0;
    padding: 0.5em 3.5em;
    text-align: center;
    text-decoration: none;
    /* shadow */
    text-shadow: 0 0 0.5em #444;
}

  原始碼地址: http://unindented.org/articles/2009/10/github-ribbon-using-css-transforms/

  27.字型壓縮

  在樣式表裡使用如下程式碼能夠幫你節省許多網頁空間。

p {
  font: italic small-caps bold 1.2em/1.0em Arial, Tahoma, Helvetica;
}

  原始碼地址: http://www.csspop.com/view/542

  28.紙頁面捲曲效果

  這種效果可以被廣泛的使用在多種容器中,檢視 demo page頁面來更好地掌握該函式的使用吧。

ul.box {
    position: relative;
    z-index: 1; /* prevent shadows falling behind containers with backgrounds */
    overflow: hidden;
    list-style: none;
    margin: 0;
    padding: 0; 
}

ul.box li {
    position: relative;
    float: left;
    width: 250px;
    height: 150px;
    padding: 0;
    border: 1px solid #efefef;
    margin: 0 30px 30px 0;
    background: #fff;
    -webkit-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset;
    -moz-box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset; 
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.27), 0 0 40px rgba(0, 0, 0, 0.06) inset; 
}

ul.box li:before,
ul.box li:after {
    content: '';
    z-index: -1;
    position: absolute;
    left: 10px;
    bottom: 10px;
    width: 70%;
    max-width: 300px; /* avoid rotation causing ugly appearance at large container widths */
    max-height: 100px;
    height: 55%;
    -webkit-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
    -moz-box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
    box-shadow: 0 8px 16px rgba(0, 0, 0, 0.3);
    -webkit-transform: skew(-15deg) rotate(-6deg);
    -moz-transform: skew(-15deg) rotate(-6deg);
    -ms-transform: skew(-15deg) rotate(-6deg);
    -o-transform: skew(-15deg) rotate(-6deg);
    transform: skew(-15deg) rotate(-6deg); 
}

ul.box li:after {
    left: auto;
    right: 10px;
    -webkit-transform: skew(15deg) rotate(6deg);
    -moz-transform: skew(15deg) rotate(6deg);
    -ms-transform: skew(15deg) rotate(6deg);
    -o-transform: skew(15deg) rotate(6deg);
    transform: skew(15deg) rotate(6deg); 
}

  原始碼地址: http://www.csspop.com/view/524

  29.發光的錨連結

  下面這段程式碼可以建立自定義的錨連結,滑鼠懸浮在上面會發光。

a {
	color: #00e;
}
a:visited {
	color: #551a8b;
}
a:hover {
	color: #06e;
}
a:focus {
	outline: thin dotted;
}
a:hover, a:active {
	outline: 0;
}
a, a:visited, a:active {
	text-decoration: none;
	color: #fff;
	-webkit-transition: all .3s ease-in-out;
}
a:hover, .glow {
	color: #ff0;
	text-shadow: 0 0 10px #ff0;
}

  30.建立CSS3 Banner

  在支援CSS3的瀏覽器中,下面的程式碼可以生成漂亮的純CSS圖案。這種效果常見於電子商務網站的產品圖片、縮圖、視訊預覽等。

.featureBanner {
    position: relative;
    margin: 20px
}
.featureBanner:before {
    content: "Featured";
    position: absolute;
    top: 5px;
    left: -8px;
    padding-right: 10px;
    color: #232323;
    font-weight: bold;
    height: 0px;
    border: 15px solid #ffa200;
    border-right-color: transparent;
    line-height: 0px;
    box-shadow: -0px 5px 5px -5px #000;
    z-index: 1;
}
.featureBanner:after {
    content: "";
    position: absolute;
    top: 35px;
    left: -8px;
    border: 4px solid #89540c;
    border-left-color: transparent;
    border-bottom-color: transparent;
}

  原始碼地址: http://www.csspop.com/view/553

  英文來源:css-snippets-for-designers

相關文章