中文字幕av高清_国产视频一二区_男女羞羞羞视频午夜视频_成人精品一区_欧美色视_在线视频这里只有精品

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  技術干貨  > 如何解決1px問題?

如何解決1px問題?

來源:千鋒教育
發布人: wjy
時間: 2022-09-07 16:56:56 1662541016

1px 問題指的是:在一些 Retina屏幕 的機型上,移動端頁面的 1px 會變得很粗,呈現出不止 1px 的效果。原因很簡單——CSS 中的 1px 并不能和移動設備上的 1px 劃等號。它們之間的比例關系有一個專門的屬性來描述:

打開 Chrome 瀏覽器,啟動移動端調試模式,在控制臺去輸出這個 devicePixelRatio 的值。這里選中 iPhone6/7/8 這系列的機型,輸出的結果就是2:

這就意味著設置的 1px CSS 像素,在這個設備上實際會用 2 個物理像素單元來進行渲染,所以實際看到的一定會比 1px 粗一些。 解決1px 問題的三種思路:

思路一:直接寫 0.5px

如果之前 1px 的樣式這樣寫:

可以先在 JS 中拿到 window.devicePixelRatio 的值,然后把這個值通過 JSX 或者模板語法給到 CSS 的 data 里,達到這樣的效果(這里用 JSX 語法做示范):

然后就可以在 CSS 中用屬性選擇器來命中 devicePixelRatio 為某一值的情況,比如說這里嘗試命中 devicePixelRatio 為2的情況:

直接把 1px 改成 1/devicePixelRatio 后的值,這是目前為止最簡單的一種方法。這種方法的缺陷在于兼容性不行,IOS 系統需要8及以上的版本,安卓系統則直接不兼容。

 

思路二:偽元素先放大后縮小

這個方法的可行性會更高,兼容性也更好。唯一的缺點是代碼會變多。

思路是先放大、后縮小:在目標元素的后面追加一個 ::after 偽元素,讓這個元素布局為 absolute 之后、整個伸展開鋪在目標元素上,然后把它的寬和高都設置為目標元素的兩倍,border值設為 1px。接著借助 CSS 動畫特效中的放縮能力,把整個偽元素縮小為原來的 50%。此時,偽元素的寬高剛好可以和原有的目標元素對齊,而 border 也縮小為了 1px 的二分之一,間接地實現了 0.5px 的效果。

代碼如下:

思路三:viewport 縮放來解決

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT
主站蜘蛛池模板: 国产免费一区二区 | 国产乱精品一区二区三区视频了 | 蜜桃久久久久久久 | 曰本人一级毛片免费完整视频 | 欧美一二三区在线观看 | 成人h精品动漫一区二区三区 | 欧美日韩在线免费观看 | av国产精品 | 国产免费无遮挡 | 亚洲成人首页 | 国产精品大片在线观看 | 国产精品第一国产精品 | 日本国产一区二区三区 | 久久狠| 国产精品成人在线观看 | 99色资源 | 日韩免费 | 色久视频| 91福利电影在线观看 | 99re在线视频| 亚洲污视频 | 一区二区三区日韩在线 | 91.com在线 | 国产高清精品一区二区三区 | 午夜视频在线观看网站 | 中文无码久久精品 | 精品国产九九 | 亚洲精品视频在线播放 | 欧美日韩国产成人在线 | 国产精品久久久久久久久久东京 | 久草久 | 国产精品二区三区在线观看 | 欧美亚洲国产一区 | 97精品国产| 黄色一级视频 | 亚洲国产精品成人综合色在线婷婷 | 日韩毛片在线免费观看 | 精品久久久久久久久久久院品网 | 免费黄色毛片网站 | 一区二区三区回区在观看免费视频 | 精品国产高清一区二区三区 |