摘要:關于一像素顯示的問題可以參考從像素問題剖析像素及和屏幕揭秘。解決方案如何解決一像素顯示問題可以參考博客種方法解決移動端屏幕邊框問題。
關于一像素顯示的問題可以參考 從1px像素問題剖析像素及viewport 和 iPhone 6 屏幕揭秘。
解決方案如何解決一像素顯示問題可以參考博客 7種方法解決移動端Retina屏幕1px邊框問題。
方案/優缺點 | 兼容性 | 顏色 | 圓角 | 總結 |
---|---|---|---|---|
0.5px 邊框 | 無法兼容安卓設備、 iOS 8 以下設備 | 支付 | 支持 | 簡單,不需要過多代碼 |
使用 border-image | 無 | 修改顏色麻煩,需要替換圖片 | 圓角需要特殊處理,并且邊緣會模糊 | 可以設置單條,多條邊框,且沒有性能瓶頸的問題 |
使用background-image實現 | 無 | 修改顏色麻煩, 需要替換圖片 | 圓角需要特殊處理,并且邊緣會模糊 | 可以設置單條,多條邊框,沒有性能瓶頸的問題 |
多背景漸變實現 | 多背景圖片有兼容性問題 | 支持 | 不支持 | 可以實現單條、多條邊框,邊框的顏色隨意設置,但是代碼量不少 |
使用 box-shadow 模擬邊框 | 無 | 邊框有陰影,顏色變淺 | 支持 | 代碼里少,可以滿足所有場景 |
viewport + rem 實現 | 無 | 支持 | 支持 | 所有場景都能滿足,一套代碼,可以兼容基本所有布局,但是老項目修改代價過大,只適用于新項目 |
偽類 + transform 實現 | 無 | 支持 | 支持(偽類和本體類都需要加border-radius) | 所有場景都能滿足,對于已經使用偽類的元素(例如clearfix),可能需要多層嵌套 |
一像素分割線
一像素分割線(viewport + rem 實現)
一像素邊框
一像素邊框(viewport + rem 實現)
最佳實踐如果公司內部已經有成熟的 “viewport + rem” 實現方案,那就不需要考慮一像素問題了。對于沒有采用該方案的項目,可以結合 ”0.5px 邊框“ 和 “偽類 + transform 實現” 的實現方案。
HTML 的 header 標簽里加入 0.5 像素檢測腳本(放在頭部可避免屏幕出現閃爍問題)
var docEl = document.documentElement; var fakeBody = document.createElement("body"); var testElement = document.createElement("div"); testElement.style.border = ".5px solid transparent"; fakeBody.appendChild(testElement); docEl.appendChild(fakeBody); if (testElement.offsetHeight === 1) { docEl.classList.add("hairlines"); } docEl.removeChild(fakeBody);
根據選擇器 .hairlines 和設備像素比來設置預定義的公共樣式
/* 分割線 */ .line-bottom, .line-left, .line-right, .line-top { position: relative; } .line-top::before, .line-bottom::after { content: ""; position: absolute; left: 0; height: 1px; width: 100%; background-color: #e8e8e8; } .line-left::before, .line-right::after { content: ""; position: absolute; top: 0; width: 1px; height: 100%; background-color: #e8e8e8; } .line-top::before { top: 0; } .line-bottom::after { bottom: 0; } .line-left::before { left: 0; } .line-right::after { right: 0; } .hairlines .line-top::before, .hairlines .line-left::before, .hairlines .line-right::after, .hairlines .line-bottom::after { transform: none; } .hairlines .line-top::before, .hairlines .line-bottom::after{ height: 0.5px; } .hairlines .line-left::before, .hairlines .line-right::after{ width: 0.5px; } @media (-webkit-min-device-pixel-ratio: 2) { .line-top::before, .line-bottom::after { transform: scaleY(0.5); } .line-left::before, .line-right::after { transform: scaleX(0.5); } } /* 由于部分顏色比較淡,按實際比例縮放可能導致看不清分割線,所以可根據具體需求來決定是否按照實際像素比縮放 */ /*@media (-webkit-min-device-pixel-ratio: 3) { .line-top::before, .line-bottom::after { transform: scaleY(0.333333); } .line-left::before, .line-right::after { transform: scaleX(0.333333); } } */ /* 邊框 */ .border { position: relative; } .border::after { content: " "; position: absolute; top: 0; left: 0; border: 1px solid #e8e8e8; box-sizing: border-box; width: 100%; height: 100%; transform-origin: left top; } .hairlines .border::after { display: none; } .hairlines .border { border: 0.5px solid #e8e8e8; } @media (-webkit-min-device-pixel-ratio: 2) { .border::after { width: 200%; height: 200%; transform: scale(0.5); } } /*@media (-webkit-min-device-pixel-ratio: 3) { .border::after { width: 300%; height: 300%; transform: scale(0.333333); } } */
一像素顯示-最佳實踐
參考文獻iPhone 6 屏幕揭秘 / iPhone 6 Screens Demystified
從1px像素問題剖析像素及viewport
7種方法解決移動端Retina屏幕1px邊框問題
移動web 1像素邊框 瞧瞧大公司是怎么做的
Retina屏的移動設備如何實現真正1px的線?
再談mobile web retina 下 1px 邊框解決方案
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/113761.html
摘要:表示單位面積上的物理像素點數目。比如原本像素高的頂部導航欄,在屏上用了個像素的高度來顯示。參考譯此像素非彼像素譯不是像素的像素不是像素移動前端開發之的深入理解移動端尺寸基礎知識張鑫旭設備像素比簡單介紹 知識 CSS 像素、物理像素、PPI CSS 像素 CSS 像素 是 Web 編程的概念,本質上是為我們 Web 開發者創建的一個抽象結構,是相對的而不是絕對的。 物理像素 物理像素 是...
摘要:我們用小米舉例,屏幕像素物理像素為,設備獨立像素為,也就是說,一個設備獨立像素就包含個物理像素,同時我們能得出。 本文主要闡述移動端布局中常遇到的一些基本概念,這些概念也適用于PC端,這些概念大概有:像素(pixel),ppi,分辨率,物理像素(physical pixel), CSS像素,設備獨立像素(devicedependent pixel) 像素 像素是圖像顯示的基本單位,同時...
閱讀 3332·2021-11-25 09:43
閱讀 3018·2021-10-15 09:43
閱讀 1975·2021-09-08 09:36
閱讀 2928·2019-08-30 15:56
閱讀 751·2019-08-30 15:54
閱讀 2695·2019-08-30 15:54
閱讀 2984·2019-08-30 11:26
閱讀 1255·2019-08-29 17:27