畫一條0.5px的線

像素是屏幕顯示最小的單位捉邢,在一個1080p的屏幕上,它的像素數(shù)量是1920 * 1080宠进,即橫邊有1920個像素藐翎,而豎邊為1080個。
像素本身有大小,如果一個像素越小阱高,那么在同樣大小的屏幕上,需要的像素點(diǎn)就越多吼旧,像素就越密集圈暗,如果一英寸有435個像素裕膀,那么它的dpi/ppi就達(dá)到了435。Macbook Pro 15寸的分辨率為2880 x 1800昼扛,15寸是指屏幕的對角線為15寸(具體為15.4),根據(jù)長寬比換算一下得到橫邊為13寸渺鹦,所以ppi為2880 / 13 = 220 ppi. 像素越密集即ppi(pixel per inch)越高毅厚,那么屏幕看起來就越細(xì)膩越高清浦箱。
在Mac/Windows上可以設(shè)置屏幕顯示的分辨率,Mac默認(rèn)為設(shè)備分辨率的一半酷窥,它的dpr = 2,即長和寬用2個像素表示1個像素板乙,所以2880個物理像素點(diǎn)實(shí)際上只表示1440個邏輯像素募逞。那么我們的問題來了,怎么在高清屏上畫一條0.5px的邊呢放接?0.5px相當(dāng)于高清屏物理像素的1px。這樣的目的是在高清屏上看起來會更細(xì)一點(diǎn)玛瘸,效果會更好一點(diǎn)苟蹈,例如更細(xì)的分隔線慧脱。

直接設(shè)置0.5px

如果我們直接設(shè)置0.5px,在不同的瀏覽器會有不同的表現(xiàn)菱鸥,使用如下代碼:

<!DOCType html>
<html>
<head>
    <meta charset="utf-8">
    <style>
        .hr {
            width: 300px;
            background-color: #000;
        }
        .hr.half-px {
            height: 0.5px;
        }
        .hr.one-px {
           height: 1px;
        }
    </style>
</head>
<body>
    <p>0.5px</p>
    <div class="hr half-px"></div>
    <p>1px</p>
    <div class="hr one-px"></div>
</body>
</html>
image.png

其中Chrome把0.5px四舍五入變成了1px殷绍,而firefox/safari能夠畫出半個像素的邊鹊漠,并且Chrome會把小于0.5px的當(dāng)成0,而Firefox會把不小于0.55px當(dāng)成1px镰烧,Safari是把不小于0.75px當(dāng)成1px楞陷,進(jìn)一步在手機(jī)上觀察IOS的Chrome會畫出0.5px的邊固蛾,而安卓(5.0)原生瀏覽器是不行的度陆。所以直接設(shè)置0.5px不同瀏覽器的差異比較大,并且我們看到不同系統(tǒng)的不同瀏覽器對小數(shù)點(diǎn)的px有不同的處理懂傀。所以如果我們把單位設(shè)置成小數(shù)的px包括寬高等,其實(shí)不太可靠郑兴,因?yàn)椴煌瑸g覽器表現(xiàn)不一樣。

使用scale縮放

<style>
.hr.scale-half {
    height: 1px;
    transform: scaleY(0.5);
}
</style>
    <p>1px + scaleY(0.5)</p>
    <div class="hr scale-half"></div>
image.png

我們發(fā)現(xiàn)Chrome/Safari都變虛了情连,只有Firefox比較完美看起來是實(shí)的而且還很細(xì)览效,效果和直接設(shè)置0.5px一樣锤灿。所以通過transform: scale會導(dǎo)致Chrome變虛了,而粗細(xì)幾乎沒有變化但校。但是如果加上transform-origin: 50% 100%:

.hr.scale-half {
    height: 1px;
    transform: scaleY(0.5);
    transform-origin: 50% 100%;
}

chrome現(xiàn)在的效果如下


image.png

線性漸變linear-gradient

<style>
.hr.gradient {
    height: 1px;
    background: linear-gradient(0deg, #fff, #000);
}
</style>
<p>linear-gradient(0deg, #fff, #000)</p>
<div class="hr gradient"></div>

image.png

inear-gradient(0deg, #fff, #000)的意思是:漸變的角度從下往上州刽,從白色#fff漸變到黑色#000浪箭,而且是線性的,在高清屏上匹表,1px的邏輯像素代表的物理(設(shè)備)像素有2px宣鄙,由于是線性漸變,所以第1個px只能是#fff冻晤,而剩下的那個像素只能是#000,這樣就達(dá)到了畫一半的目的鼻弧。

boxshadow

<style>
.hr.boxshadow {
    height: 1px;
    background: none;
    box-shadow: 0 0.5px 0 #000;
}
</style>
<p>box-shadow: 0 0.5px 0 #000</p>
<div class="hr boxshadow"></div>

viewport

<meta name="viewport" content="width=device-width,initial-sacle=0.5">

其中width=device-width表示將viewport視窗的寬度調(diào)整為設(shè)備的寬度攘轩,這個寬度通常是指物理上寬度。默認(rèn)的縮放比例為1時歼捏,如iphone 6豎屏的寬度為750px,它的dpr=2瓣履,用2px表示1px寂诱,這樣設(shè)置之后viewport的寬度就變成375px痰洒。但是我們可以改成0.5,viewport的寬度就是原本的750px脯宿,所以1個px還是1px,正常畫就行连霉,但這樣也意味著UI需要按2倍圖的出跺撼,整體面面的單位都會放大一倍。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末歉井,一起剝皮案震驚了整個濱河市哩至,隨后出現(xiàn)的幾起案子蜜自,更是在濱河造成了極大的恐慌,老刑警劉巖重荠,帶你破解...
    沈念sama閱讀 212,599評論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件戈鲁,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)待笑,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,629評論 3 385
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來癌压,“玉大人荆陆,你說我怎么就攤上這事≈南” “怎么了泡挺?”我有些...
    開封第一講書人閱讀 158,084評論 0 348
  • 文/不壞的土叔 我叫張陵命浴,是天一觀的道長。 經(jīng)常有香客問我媳溺,道長悬蔽,這世上最難降的妖魔是什么冲茸? 我笑而不...
    開封第一講書人閱讀 56,708評論 1 284
  • 正文 為了忘掉前任屯阀,我火速辦了婚禮,結(jié)果婚禮上轴术,老公的妹妹穿的比我還像新娘难衰。我一直安慰自己,他們只是感情好逗栽,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,813評論 6 386
  • 文/花漫 我一把揭開白布盖袭。 她就那樣靜靜地躺著,像睡著了一般彼宠。 火紅的嫁衣襯著肌膚如雪鳄虱。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 50,021評論 1 291
  • 那天凭峡,我揣著相機(jī)與錄音拙已,去河邊找鬼。 笑死摧冀,一個胖子當(dāng)著我的面吹牛系宫,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播潮罪,決...
    沈念sama閱讀 39,120評論 3 410
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼屯碴!你這毒婦竟也來了导而?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,866評論 0 268
  • 序言:老撾萬榮一對情侶失蹤虚缎,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后创坞,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體题涨,經(jīng)...
    沈念sama閱讀 44,308評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡闰渔,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,633評論 2 327
  • 正文 我和宋清朗相戀三年蝌以,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片溶推。...
    茶點(diǎn)故事閱讀 38,768評論 1 341
  • 序言:一個原本活蹦亂跳的男人離奇死亡睹耐,死狀恐怖硝训,靈堂內(nèi)的尸體忽然破棺而出赘风,到底是詐尸還是另有隱情邀窃,我是刑警寧澤瞬捕,帶...
    沈念sama閱讀 34,461評論 4 333
  • 正文 年R本政府宣布,位于F島的核電站笋轨,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏钾挟。R本人自食惡果不足惜掺出,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 40,094評論 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望牍汹。 院中可真熱鬧慎菲,春花似錦、人聲如沸解幼。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,850評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽牵素。三九已至,卻和暖如春粱挡,著一層夾襖步出監(jiān)牢的瞬間榕堰,已是汗流浹背逆屡。 一陣腳步聲響...
    開封第一講書人閱讀 32,082評論 1 267
  • 我被黑心中介騙來泰國打工砍的, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 46,571評論 2 362
  • 正文 我出身青樓馆衔,卻偏偏與公主長得像拷获,于是被迫代替她去往敵國和親匆瓜。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,666評論 2 350

推薦閱讀更多精彩內(nèi)容