使用css3做0.5px的細(xì)線的示例代碼

Webapp中的CSS3實現(xiàn) 0.5px的細(xì)線
感覺很長時間沒寫過博客了,最近生活還算穩(wěn)定,過得較為充實,所以又要開始寫寫東西了,一個是為了做些記錄,是怕自己某一天,忘記了,回頭翻翻博客,就會再次的拾起來,記憶,就是這樣。
曾看過淘寶,京東,易迅,一號店等等電商的移動端網(wǎng)站,這些大的電商站的共同特點是做的精致,用戶體驗良好,其中在布局方面 , 0.5px的線看上去就比1px的線看上去要精致很多。
方法一:使用漸變來做
html代碼:
<div></div>
css代碼:
.bd-t{ position:relative; } .bd-t::after { content: " "; position: absolute; left: 0; top: 0; width: 100%; height: 1px; background-image: linear-gradient(0deg, transparent 50%, #e0e0e0 50%); }
Be careful ! 注意此處有坑!?。。?/p>
對于不同瀏覽器的兼容,我們需要使用不同的前綴如:
-webkit-linear-gradient -ms-linear-gradient -o-linear-gradient
坑就在這些前綴里: 我們把代碼里的height 1px 變成 100px , 參數(shù)同為 0deg, transparent 50%, #e0e0e0 50%
并使用最新版的chrome來測試 。
linear-gradient 有如下結(jié)果:
經(jīng)過一系列的測試總結(jié),我們可以推理出下面的漸變方式:
webkit-linear-gradient 的代碼效果圖如下:
經(jīng)總結(jié),我們看到-webkit前綴的漸變方式為:
其他的前綴如果用到,還請小伙伴們自己來嘗試填坑!
說明:
推薦這種寫法,這是百度糯米移動站的做法(如果沒改版的話):http://m.nuomi.com/ ,從上述代碼的描述中,可以看到,為了實現(xiàn)盒子頂部邊框0.5px的偽代碼:border-top:0.5px solid #e0e0e0;
的效果,使用after,作為一個鉤子,寬度100%,高度1px,背景漸變,一半透明,一半有顏色,這么干是可以的。同理,底部,左邊和右邊的細(xì)線,都是同一個道理了。當(dāng)然,如果需要組合使用,盒子之間的嵌套使用,也是可以的,或者你有自己的想法(當(dāng)然做法有很多種!)…
方式二: 使用縮放
html代碼:
<div></div>
css代碼:
.bd-t{ position:relative; } .bd-t:after{ content: " "; position: absolute; left: 0; top: 0; width: 100%; height: 1px; background-color: #e0e0e0; /* 如果不用 background-color, 使用 border-top:1px solid #e0e0e0; */ -webkit-transform: scaleY(.5); transform:scaleY(.5); }
說明
這是實現(xiàn)盒子上邊框0.5px的做法, 不是很推薦這種做法,因為經(jīng)過測試,一些手機端瀏覽器顯示的不是太好。這種實現(xiàn)的原理是: 在Y軸方向上,壓縮一半。就像上面注釋的那樣。
如果你覺得效果不太好,這里有一個 fallback or workaround, whatsoever: 就是上面注釋掉的那種做法:可以嘗試使用border-top:1px solid #e0e0e0;
代替background-color的做法,京東就是這么做的(如果沒改版的話): http://m.jd.com/
方式二的拓展 : 如果要實現(xiàn)四周全是0.5px的線條的話 :
html代碼:
<div class='bd-all'></div>
css代碼:
.bd-all{ position:relative; } .bd-all:after{ content: " "; position: absolute; left: 0; top: 0; z-index:-1; width: 200%; height:200%; border:1px solid #e0e0e0; -webkit-transform-origin: 0 0; transform-origin: 0 0; -webkit-transform: scale(.5, .5); transform: scale(.5, .5); }
說明 :
這是實現(xiàn)一個盒子四周0.5px的做法, 如果加入border-radius圓角效果,會發(fā)現(xiàn),有些手機會有圓角發(fā)虛的情況,不過影響不是很大。如果有兩個盒子,上面一個盒子沒有邊框效果,下面盒子有邊框效果,兩個盒子一樣寬,上下在一起的布局方式,你會發(fā)現(xiàn),在手機上有時候會對不齊… 錯開了0.5px,原因已經(jīng)很明了了…還有那個z-index
,可以根據(jù)不同需求來調(diào)整使用,如果可以的話,不使用也是可以的。
方式三: 使用background-image和css3的九宮格裁減
京東之前是這么做的,現(xiàn)在已經(jīng)不被使用了。具體做法,請看下面demo結(jié)構(gòu):
├─demo/ ························ demo 目錄 └─┬─ test.html ··············· test.html 文件 └─── pic.png ·················· png 圖片文件
在test.html 中 有如下關(guān)鍵代碼:
html 結(jié)構(gòu):
<div class="bd-t"></div>
css 結(jié)構(gòu):
.bd-t{ position: relative; } .bd-t::after { content: " "; position: absolute; left: 0; top: 0; width: 100%; border-top: 1px solid transparent; /* 下面用 stretch 和 round 都可以 */ border-image: url('pic.png') 2 1 1 1 stretch; -webkit-border-image: url('pic.png') 2 1 1 1 stretch; }
而 pic.png 的九宮格切法,如下圖:
具體有關(guān) border-image 的用法,網(wǎng)上有很多:
w3c 上的這個講的不是很具體:http://www.dbjr.com.cn/w3school/cssref/pr_border-image.htm
在 MDN 上 有明確的介紹,并且有很多配圖,包括兼容性等等:https://developer.mozilla.org/en-US/docs/Web/CSS/border-image
但是不推薦這種寫法,畢竟圖片質(zhì)量比較大,能用代碼解決的,不用圖片。在這里border-width 是 1px , 但是 背景是有2px的距離,所以在1px的border-top上,顯示出有顏色的高度就是0.5px, 同理,底邊,左邊和右邊的0.5px,也都很容易實現(xiàn)。 這個就是css3的魅力體現(xiàn)(這個現(xiàn)在兼容性也不是很好,在一些較低端的安卓瀏覽器和一些版本的safari 支持的也不是很好)。
方式四 (推薦): weui的實現(xiàn)方式 :
這是一款微信團隊開發(fā)的UI 組件 詳情見: weui , 它的使用方式是這樣的:
.weui-cell:before{ content: " "; position: absolute; left: 0; top: 0; right: 0; height: 1px; border-top: 1px solid #D9D9D9; color: #D9D9D9; -webkit-transform-origin: 0 0; transform-origin: 0 0; -webkit-transform: scaleY(0.5); transform: scaleY(0.5); }
方式五: 使用同周邊相似的淺色,利用視覺效果,讓用戶產(chǎn)生錯覺
這個就考驗設(shè)計師的功力了 :)
其他說明:不是很推薦使用漸變來做 , 在移動設(shè)備上可以看到,但在一些瀏覽器上看不到,不便于調(diào)試。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
- 這篇文章主要介紹了css中引入svg來兼容部分安卓機顯示0.5px邊框的示例的相關(guān)資料,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-02-22
- 這篇文章主要介紹了css實現(xiàn)各種0.5px的線(小結(jié)),主要介紹了0.5px邊框、0.5px圓角邊框、0.5px左邊線、0.5px右邊線、0.5px底部線,小編覺得挺不錯的,現(xiàn)在分享給大家,也給2018-06-28