日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

在移動端開發時,經常會遇到在視網膜屏幕中元素邊框變粗的問題。本文將帶你探討邊框變粗問題的產生原因及介紹目前市面上最好的解決方法。

目前解決移動端1px邊框最好的方法

在移動端里,邊框有什么不一樣(按我來說,感覺顏色不一樣)

1px 邊框問題的由來

蘋果 iphone4 首次提出了 Retina Display(視網膜屏幕)的概念,在 iPhone4 使用的視網膜屏幕中,把 2x2 個像素當 1 個物理像素使用,即使用 2x2 個像素顯示原來 1 個物理像素顯示的內容,從而讓 UI 顯示更精致清晰,這 2x2 個像素叫做邏輯像素。像這種像素比(像素比(即dpr)= 物理像素 / 邏輯像素)為 2 的視網膜屏幕也被稱為二倍屏,目前市面上還有像素比更高的三倍屏、四倍屏。而 css 中 1px 指的是物理像素,因此,設置為 1px 的邊框在 dpr = 2 的視網膜屏幕中實際占用了 2 個邏輯像素的寬度,這就導致了界面邊框變粗的視覺體驗。

使用 transform 解決

通過設置元素的 box-sizing 為 border-box,然后構建偽元素,再使用 CSS3 的 transform 縮放,這是目前市面上最受推崇的解決方法。這種方法可以滿足所有的場景,而且修改靈活,唯一的缺陷是,對于已使用偽元素的元素要多嵌套一個無用元素。具體的實現如下:

.one-pixel-border {
  position: relative;
  box-sizing: border-box;
}

.one-pixel-border::before {
  display: block;
  content: "";
  position: absolute;
  top: 50%;
  left: 50%;
  width: 200%;
  height: 200%;
  border: 1px solid red;
  transform: translate(-50%, -50%) scale(0.5, 0.5);
}

這樣就可以得到 0.5px 的邊框。

還可以結合媒體查詢(@media)解決不同 dpr 值屏幕的邊框問題,如下:

@media screen and (-webkit-min-device-pixel-ratio: 2), (min-resolution: 2dppx) {
  ...
}

@media screen and (-webkit-min-device-pixel-ratio: 3), (min-resolution: 3dppx) {
  ...
}

注意:IOS 系統的 safari 瀏覽器不支持標準的 min-resolution,使用非標準的 min-device-pixel-ratio。

使用 pixel-border.css 解決

pixel-border.css是一個解決移動端 1px 邊框的通用 CSS 工具。使用 transform 的解決方法,僅有幾行的源碼,使用起來非常方便,是目前發現最好的解決方法。

安裝

npm安裝:

npm install pixel-border --save

yarn安裝:

yarn add pixel-border

瀏覽器安裝,建議安裝壓縮后的版本:

<link rel="stylesheet" href="path/to/pixel-border.min.css"><link>

使用

pixel-border 通過元素的 ::before 偽元素使用 transform 縮放為元素設置邊框。因此,你可以使用原生的 CSS 邊框屬性為原素設置邊框,只需要在元素上添加一個 pixel-border 或 pixel-border="true" 的屬性,并設置元素的 border-style 值即可。如下會創建一個單像素邊框:

<div pixel-border style="border-style: solid;">單像素邊框</div>

注意:pixel-border已為元素的邊框設置為固定值 1px,因此不要為元素再設置 border-width,并且元素的 box-sizing 值被設置為 border-box,請不要重置為其他類型的值。

設置任意邊框:

設置元素某一邊的邊框時,只需為元素設置 border-top-style、border-bottom-style、border-left-style、border-right-style 其中一項的值,并設置元素 border-color 的值即可。如下設置上邊邊框:

<style>
  .border-top {
    border-top-style: solid;
    border-top-color: red;
  }
</style>

<div class="border-top" pixel-border>上邊框</div>

設置圓角邊框:

當需要圓角邊框時,始終為 border-radius 設置百分比值。如下:

<style>
  .border-radius {
    width: 100px;
    height: 100px;
    border-style: solid;
    border-color: red;
    border-radius: 10%;
  }
</style>

<div class="border-radius" pixel-border>圓角邊框</div>

分享到:
標簽:邊框 px
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定