移動端適配問題

適配問題

怎么適配iphone6
1px問題

為什么頁面與設計稿會出現偏差?

dpr=設備像素/ css像素
,只有dpr等于1的時候,實際效果和設計稿的尺寸比例才是1:1。

因為iPhone6的DPR(設備像素比)為2,設備像素為750,所以iPhone6的理想視口尺寸為375px。

因為設計稿是基于設備像素,頁面是基于css像素的。css中的寬度是基于理想視口的(寬度375px),設計圖上是基于設備寬度750px,所以尺寸不對。


怎么處理?

init-scale=0.5

缺陷:但是寬度不能自適應


??rem大法

基于

html
標簽的
font-size
設置的

手淘的做法:

把縮放尺寸設置成dpr的倒數。

讀設備寬度,動態設置meta標簽的 content屬性中的

maximun
,
minimum
,
user-scable

<html>
<head><title></title><meta charset="utf-8" /><meta name="viewport" content="" /><style>body{margin: 0;padding: 0;}.box{width: 2.66666667rem;height: 2.66666667rem;background: red;}</style>
</head>
<body><div class="box"></div><script>var scale = 1 / window.devicePixelRatio;document.querySelector('meta[name="viewport"]').setAttribute('content','width=device-width,initial-scale='   scale   ', maximum-scale='   scale   ', minimum-scale='   scale   ', user-scalable=no');document.documentElement.style.fontSize = document.documentElement.clientWidth / 10   'px';</script>
</body>
</html>

網易的做法

現在的設計稿都是750px寬度(p6的寬),那要想實現

css樣式:設計圖=1:100
這種比較方便的折算方式,font-size就要設置成7.5px;

也就是說

1rem = 7.5px

<html>
<head><title></title><meta charset="utf-8" /><meta name="viewport" content="width=device-width,initial-scale=1,maximum-scale=1,user-scalable=no" /><style>body{margin: 0;padding: 0;}.box{width: 2rem;height: 2rem;background: red;}</style>
</head>
<body><div class="box"></div><script>document.documentElement.style.fontSize = document.documentElement.clientWidth / 7.5   'px';</script>
</body>
</html>

總結

rem是為了實現移動端自適應布局。通過在

html
元素下設置
font-size
定義。

另外,手淘的做法是通過判斷設備的dpr,將縮放規模scale設置為dpr的倒數,再用js動態設置

meta
標簽的
content
屬性和font-size基準值的大小。

網易的做法是,禁用用戶縮放,scale始終為1,將font-size設置為625%,即 1rem=100px。


1px問題

如何實現移動端的1px邊框

方法一:
transformY:scale(50%)
方法二:
border-width:0 0 2px 0;
border-image:url("xxx.png") 0 0 2 0 stretch // 圖片地址 上下剪切 左右剪切 上下邊寬 左右邊寬 圖片拉伸

vm/vh rem大法

vm/vh是未來的趨勢

rem方式弊端:需要動態計算根字體大小

做法:用vm/vh來計算根字體大小,剩下的自適應布局依舊按照rem的方法

用vm/vh做適配頁面

??關于vm/vh

1. 與%百分比的區別

vm/vh 是基于視窗的
%基于父元素

2. 使用場景

隨著頁面不同,文字圖片縮小放大(適配頁面)

3. 與rem的區別

vm/vh沒有最大、最小寬大的限制(設備很小的時候,圖文會縮得特別特別小……)

措施:

1.解決背景過小問題

body{min-width:xxx px;max-width: xxx px;
}

2.媒體查詢限制根文字大小(解決文字過小問題)

html { font-size: ($vw_fontsize / ($vw_design / 2)) * 100vw; // 同時,通過Media Queries 限制根元素最大最小值 @media screen and (max-width: 320px) { font-size: 64px; } @media screen and (min-width: 540px) { font-size: 108px; } }

本文轉載于:猿2048https://www.mk2048.com/blog/blog.php?id=0bchaa&title=移動端適配問題

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/371093.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/371093.shtml
英文地址,請注明出處:http://en.pswp.cn/news/371093.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

用Java彈出創建新的消息通知

首先創建JFrame作為彈出窗口。 在其中添加一些JLabel以包含信息&#xff0c;并在適當的位置分配它們&#xff0c;使其看起來像一條通知消息。 下面給出了示例代碼&#xff1a; String message You got a new notification message. Isnt it awesome to have such a notificat…

mysql游標表間數據遷移_FalseMySQL存儲過程--gt;通過游標遍歷和異常處理遷移數據到歷史表-mysql-第二電腦網...

-- 大表數據遷移,每天凌晨1點到5點執行,執行間隔時間10分鐘&#xff0c;遷移舊數據到歷史表。DELIMITER $$USE dbx$$電腦技術網對《FalseMySQL存儲過程-->通過游標遍歷和異常處理遷移數據到歷史表》總結來說&#xff0c;為我們程序員很實用。DROP PROCEDURE IF EXISTS pro_x…

課后作業-閱讀任務-閱讀筆記-2

好的單元測試的標準&#xff1a; 1>單元測試應該在最基本的功能/參數上驗證程序的正確性 2>單元測試必須由最熟悉代碼的人&#xff08;程序的作者&#xff09;來寫 3>單元測試后&#xff0c;機器狀態保持不變 4>單元測試要快&#xff08;一個測試的運行時間是幾秒鐘…

定位-固定定位

把box2設為固定定位&#xff1a; <!DOCTYPE html> <html lang"en" dir"ltr"><head><meta charset"utf-8"><title>定位</title><style media"screen">.box1{width:100px; height: 100px;ba…

垃圾自動回收

自動回收 自動回收的語言&#xff1a;根據變量是否還被引用&#xff0c;來確定是否應該回收Javascript內存泄露 由于js回調及閉包的特性&#xff0c;當方法嵌套太多的時候&#xff0c;可能回最外層的變量可能一直都被引用著&#xff0c;這樣就導致變量一直沒有被回收&#xff0…

Java并發執行器的懶惰開發人員簡介

如果我告訴您util.concurrent API自2004年起提供此類服務&#xff0c;我就會自欺欺人。但是&#xff0c;我想回顧一下一些很酷的功能。 并發專家&#xff0c;現在是時候關閉該窗口了。 所有其他人&#xff0c;請緊緊抓住樂趣。 你不會忘記你的根源 執行程序是具有單個執行方法…

《我們應該怎樣做需求分析》閱讀筆記

認識&#xff1a;軟件需求分析是貫穿軟件項目從出生到成長或者死亡的&#xff0c;我們必須搞清楚到手的軟件是為了什么要做什么做成什么樣&#xff0c;通過顧客的描述彼此的合作分析需求與業務邏輯&#xff0c;不斷改進從而實現軟件在合理范圍內符合顧客要求。 怎么做&#xff…

Java代碼格式化算法_一個時間格式化的工具類:TimeUtil

源代碼如下&#xff1a;import android.content.Context;import android.text.TextUtils;import android.text.format.DateUtils;import java.text.Format;import java.text.SimpleDateFormat;import java.util.Calendar;import java.util.Date;import java.util.regex.Matcher…

(轉)VS2010/MFC編程入門之前言

雞啄米的C編程入門系列給大家講了C的編程入門知識&#xff0c;大家對C語言在語法和設計思想上應該有了一定的了解了。但是教程中講的例子只是一個個簡單的例程&#xff0c;并沒有可視化窗口。雞啄米在這套VS2010/MFC編程入門教程中將會給大家講解怎樣使用VS2010進行可視化編程&…

JavaOne 2012:JavaFX圖形技巧和竅門

我回到希爾頓&#xff08;皇家宴會廳B&#xff09;看了Richard Bair的&#xff08;Oracle Java客戶架構師&#xff09;的“ JavaFX圖形技巧和竅門”。 Bair與FX Experience相關聯&#xff0c;并且顯然了解JavaFX。 拜爾說&#xff0c;他演講的主題是表演。 他告誡說&#xff0c…

web前端知識點1

1. input屬于窗體元素,層級顯示比flash、其它元素都高。請判斷這句話的正確與否。 錯誤 層級顯示優先級&#xff1a; frameset > 表單元素 > 非表單元素 在html中&#xff0c;幀元素&#xff08;frameset&#xff09;的優先級最高&#xff0c;表單元素比非表單元素的優…

18. 使用模板【從零開始學Spring Boot】

轉&#xff1a;http://blog.csdn.net/linxingliang/article/details/52017098 18.1 使用thymeleaf 整體步驟&#xff1a; &#xff08;1&#xff09; 在pom.xml中引入thymeleaf; &#xff08;2&#xff09; 如何關閉thymeleaf緩存 &#xff08;3&#xff09; …

java單元測試算初級_Java____Eclipse下JUnit單元測試(初級)

給大家分享一個鏈接希望對你們有幫助 http://blog.csdn.net/huangbiao86/article/details/6709742今天看圖片命名唯一的策略時看到有個大大用JUnit測試&#xff0c;神奇的樣子&#xff0c;遂上網搜集來三篇JUnit測試的入門文章&#xff0c;作為參考。原作地址在上面&#xff0c…

Hadoop + Amazon EC2 –更新的教程

在Hadoop的Wiki頁面上放置了一個舊教程&#xff1a; http : //wiki.apache.org/hadoop/AmazonEC2 &#xff0c;但是最近我不得不遵循本教程&#xff0c;并且我注意到它沒有涵蓋某些Amazon新功能。 建議您已經熟悉Hadoop的基礎來遵循本教程&#xff0c;可以在Hadoop的主頁http:…

oracle11g 修改字符集 修改為ZHS16GBK

轉&#xff1a;http://www.cnblogs.com/jay-xu33/p/5210098.html oracle11g 修改字符集 修改為ZHS16GBK1.cmd下,cd到oracle數據庫軟件的服務器端 如&#xff1a;D:\app\Administrator\product\11.2.0\dbhome_1\BIN 2.輸入set ORACLE_SID你想進入的數據庫的那個sid 3.輸入 sqlpl…

瀏覽器內核

瀏覽器的四大內核&#xff1a; Trident&#xff0c;Gecko&#xff0c;Webkit&#xff0c;Blink。 不同的內核對網頁編寫語法的解釋也有不同&#xff0c;進而導致同一個頁面在不同內核的瀏覽器下顯示出來的效果也會有所出入&#xff0c;這也是作為一個前端工程師需要了解不同瀏…

2017.4.14 Java String.split()用法小結

在java.lang包中有String.split()方法,返回是一個數組 我在應用中用到一些,給大家總結一下,僅供大家參考: 1、如果用“.”作為分隔的話,必須是如下寫法,String.split("\\."),這樣才能正確的分隔開,不能用String.split("."); 2、如果用“|”作為分隔的話,必…

java線程統一_Java線程結果不一致

我有一個實現可運行的線程類和一個int計數器作為實例變量。兩種同步方法add和sub。當我以某種方式運行測試類時&#xff0c;它幾次會輸出錯誤的結果。據我了解&#xff0c;當方法同步時&#xff0c;整個對象將被鎖定以供其他線程訪問&#xff0c;這種邏輯每次我們都應該獲得相同…

markdown-Macdown

#標題 [頁面錨點](#name) > <a name"name"></a>文字 **加粗**(Command-B) *斜體*(Command-I) * * * 或者 - -- 無序列表 1. 2. 3. 有序列表 、、、 代碼段 、、、 或者用 ~ 代替 或者 上下空一行每行縮進4個空格 <http://www.baidu.com>鏈…

什么是web標準??

web標準 不是某一個標準&#xff0c;而是一系列標準的集合。網頁主要由三部分組成&#xff1a;結構&#xff08;Structure&#xff09;、表現&#xff08;Presentation&#xff09;和行為&#xff08;Behavior&#xff09;。對應的標準也分三方面&#xff1a;結構化標準語言主…