摘要:這個(gè)問(wèn)題的解決方案有很多,個(gè)人覺(jué)得最簡(jiǎn)單方面的還是大漠大大的一種解決方案。
先科普一下,HTML5并不是一項(xiàng)技術(shù),而是一個(gè)標(biāo)準(zhǔn)。移動(dòng)端的適配方案
所以其實(shí)要么我們是作為理論派討論HTML5標(biāo)準(zhǔn),要么是作為實(shí)踐派討論HTML5標(biāo)準(zhǔn)在某瀏覽器的應(yīng)用。
H5 實(shí)際上是一個(gè)解決方案,一個(gè)看起來(lái)酷炫的移動(dòng)端onepage網(wǎng)站的解決方案
rem適配
優(yōu)點(diǎn):
1. 引用簡(jiǎn)單,布局簡(jiǎn)便 2. 根據(jù)設(shè)備屏幕的DPR,自動(dòng)設(shè)置最合適的高清縮放 3. 有效解決移動(dòng)端真實(shí)1px問(wèn)題
但是絕不是每個(gè)地方都要用rem,rem只適用于固定尺寸!
在這里rem也是一種單位,并且可以為咱們的布局提供無(wú)線的變化,根據(jù)開(kāi)發(fā)者的設(shè)定,它將會(huì)在不同的分辨率屏幕上展示不同的色彩。
這個(gè)單位的定義和em類(lèi)似,不同的是em是相對(duì)于父元素,而rem是相對(duì)于根元素,當(dāng)我們指定一個(gè)元素的font-size為2rem的時(shí)候,也就說(shuō)這個(gè)元素的字體大小為根元素字體大小的兩倍,如果html的font-size為12px,那么這個(gè)2rem的元素font-size就是24px。
html {font-size: 12px;} h1 { font-size: 2rem; } 2*12 = 24px html {font-size: 16px;} h1 { font-size: 2rem; } 2*16 = 32px
單位 | 定義 | 特點(diǎn) |
---|---|---|
rem | font size of the root element | 以根元素字體大小為基準(zhǔn) |
em | font size of the element | 以父元素字體大小為基準(zhǔn) |
當(dāng)然上邊只是我們介紹rem簡(jiǎn)單的示例,具體運(yùn)用到項(xiàng)目中我還需進(jìn)行rem的計(jì)算,根據(jù)根元素的font-size通過(guò)Javascript來(lái)計(jì)算我們的rem單位適配
選取一個(gè)設(shè)備寬度作為基準(zhǔn),設(shè)置其根元素大小,其他設(shè)備根據(jù)此比例計(jì)算其根元素大小。比如使得iPhone6根元素font-size=16px。
設(shè) 備 | 設(shè)備寬度 | 根元素font-size/px | 寬度/rem |
---|---|---|---|
iPhone5 | 320 | 計(jì)算 | - |
iPhone6 | 375 | 16 | 23.4375 |
iPhone7 | 375 | 16 | 23.4375 |
iPhone7plus | 414 | 計(jì)算 | - |
根元素fontSize公式:width/fontSize = deviceWidth/deviceFontSize
下方為動(dòng)態(tài)計(jì)算 (function flexible (window, document) { var docEl = document.documentElement var dpr = window.devicePixelRatio || 1 // adjust body font size function setBodyFontSize () { if (document.body) { document.body.style.fontSize = (12 * dpr) + "px" } else { document.addEventListener("DOMContentLoaded", setBodyFontSize) } } setBodyFontSize(); // set 1rem = viewWidth / 10 function setRemUnit () { var rem = docEl.clientWidth / 10 console.log(rem) docEl.style.fontSize = rem + "px" } setRemUnit() // reset rem unit on page resize window.addEventListener("resize", setRemUnit) window.addEventListener("pageshow", function (e) { if (e.persisted) { setRemUnit() } }) // detect 0.5px supports if (dpr >= 2) { 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) } }(window, document))
上方的代碼則是本人經(jīng)常使用的rem計(jì)算方法,我們可以根據(jù)我們自己的需求設(shè)定基于多大的屏幕以及rem的換算倍率等
百分比方案使用百分比布局大部分是可行的,它會(huì)讓布局隨著屏幕的大小自動(dòng)縮放,而且不用寫(xiě)太多的css樣式,以及js相關(guān)的計(jì)算操作,但是文字就存在非常大的問(wèn)題了,由于文字是固定大小,在屏幕dpr變化的時(shí)候,文字的CSS像素不變,就導(dǎo)致了文字在頁(yè)面中的占位發(fā)生了變化。這樣的結(jié)果就是,文字過(guò)多或者屏幕dpr過(guò)小的時(shí)候,會(huì)發(fā)生溢出;但是如果按照小屏幕為基準(zhǔn),又會(huì)發(fā)生字體太小這種情況。vw方案
百分比在當(dāng)前移動(dòng)端適配排版的時(shí)候,更多地會(huì)作為section級(jí)別元素的兼容排版。這個(gè)也要和設(shè)計(jì)稿中的效果相關(guān),如果設(shè)計(jì)稿中要求一個(gè)元素定寬,那么就直接用px來(lái)保證寬度就可以了。
vw也是css的單位,1vw相當(dāng)于1%,比如:瀏覽器視口尺寸為370px,那么 1vw = 370px * 1% =6.5px(瀏覽器會(huì)四舍五入向下取7),
我們來(lái)看看vw的瀏覽器和手機(jī)的兼容性問(wèn)題
瀏覽器
手機(jī)
在移動(dòng)端 iOS 8 以上以及 Android 4.4 以上獲得支持,并且在微信 x5 內(nèi)核中也得到完美的全面支持
vw自身將整個(gè)可見(jiàn)視口橫向分成了100份,每一個(gè)單位就是1vw,這個(gè)單位最大的優(yōu)勢(shì)就是在移動(dòng)端的時(shí)候,無(wú)論是豎屏或者橫屏,vw永遠(yuǎn)都是針對(duì)于橫向的,比rem的方案好在當(dāng)屏幕大小發(fā)生變化(順便兼容了以后的可調(diào)節(jié)屏幕大小的移動(dòng)設(shè)備[手動(dòng)斜眼])的時(shí)候,不會(huì)讓頁(yè)面崩掉。
對(duì)于移動(dòng)設(shè)備來(lái)說(shuō),比如iphone6+的375pxCSS像素寬度,1vw就等于3.75px,通過(guò)這個(gè)單位可以解決上面的依賴(lài)于腳本綁定根元素font-size的問(wèn)題,在豎屏和橫屏下面都有比較好的效果
$w-base: 375px $w-base-design: 750px @function px2vw($px) @return ($px / $w-base-design) * 100vw
雖然vw可以得到很好的支持,但是不會(huì)得到視覺(jué)稿原本的像素值了。在后期進(jìn)行維護(hù)的時(shí)候會(huì)增加很多很多很多麻煩,前期打怪爽,后期裝備維護(hù)難
淘寶移動(dòng)端適配方案淘寶
移動(dòng)端事件click:?jiǎn)螕羰录?,?lèi)似于PC端的click,但在移動(dòng)端中,連續(xù)click的觸發(fā)有200ms ~ 300ms的延遲 touchstart:手指觸摸到屏幕會(huì)觸發(fā) touchmove:當(dāng)手指在屏幕上移動(dòng)時(shí),會(huì)觸發(fā) touchend:當(dāng)手指離開(kāi)屏幕時(shí),會(huì)觸發(fā) touchcancel:可由系統(tǒng)進(jìn)行的觸發(fā),比如手指觸摸屏幕的時(shí)候,突然alert了一下,或者系統(tǒng)中其他打斷了touch的行為,則可以觸發(fā)該事件移動(dòng)端常見(jiàn)問(wèn)題
1px問(wèn)題
大家都知道我們?cè)賹?xiě)web端適配的時(shí)候還需要兼容ie瀏覽器,這是因?yàn)闉g覽器的內(nèi)核都不一樣,而且我們的屏幕大小,屏幕廠商也是不一樣,時(shí)常會(huì)發(fā)生缺少像素或者多像素現(xiàn)象,其實(shí)手機(jī)也一樣屏幕大小不一,瀏覽器也是各式各樣,拿iphone6為例,其dpr(device pixel ratio)設(shè)備像素比為2,css中一個(gè)1x1的點(diǎn),其實(shí)在iphone6上是2x2的點(diǎn),并且1px的邊框在devicePixelRatio = 2的Retina屏下會(huì)顯示成2px,在iPhone6 Plus下甚至?xí)@示成3px。
這個(gè)問(wèn)題的解決方案有很多,個(gè)人覺(jué)得最簡(jiǎn)單方面的還是大漠大大的一種解決方案。
使用postcss-write-svg插件
利用meta標(biāo)簽對(duì)viewport進(jìn)行控制
2.刪除默認(rèn)的蘋(píng)果工具欄和菜單欄
3.在web app應(yīng)用下?tīng)顟B(tài)條(屏幕頂部條)的顏色 (iphone設(shè)備中的safari私有meta標(biāo)簽 ) 默認(rèn)值為default(白色),可以定為black(黑色)和black-translucent(灰色半透明) 若值為“black-translucent”將會(huì)占據(jù)頁(yè)面px位置,浮在頁(yè)面上方
4.允許全屏模式瀏覽 (iphone設(shè)備中的safari私有meta標(biāo)簽 )
5.禁止了把數(shù)字轉(zhuǎn)化為撥號(hào)鏈接 在iPhone上默認(rèn)將電話號(hào)碼變?yōu)槌溄樱ㄋ{(lán)色字體)并且點(diǎn)擊這個(gè)數(shù)字還會(huì)自動(dòng)撥號(hào)
6.ios click點(diǎn)擊事件延時(shí)300ms
7.移動(dòng)端如何定義字體font-family
8.移動(dòng)端字體單位font-size選擇px還是rem (new)
9.移動(dòng)端touch事件(區(qū)分webkit 和 winphone) (new)
更多問(wèn)題
webApp與響應(yīng)式區(qū)別響應(yīng)式: 設(shè)計(jì)通過(guò)CSS3的MQ(Media queries),使網(wǎng)頁(yè)在不同設(shè)備上都可以自動(dòng)適應(yīng),從而具有更加優(yōu)秀的表現(xiàn)效果。 而且響應(yīng)式設(shè)計(jì)不僅用在移動(dòng)網(wǎng)站,在PC端也有不同屏幕的適配,而且移動(dòng)端和PC端可以只使用一套代碼,這就是全平臺(tái)的響應(yīng)式設(shè)計(jì) Webapp: HTML5移動(dòng)端(移動(dòng)網(wǎng)站、混合應(yīng)用、WebAPP)為了解決屏幕適配經(jīng)常會(huì)使用響應(yīng)式設(shè)計(jì)(流式布局、CSS3媒體查詢(xún)), 但是響應(yīng)式設(shè)計(jì)并不是必須,也可以使用流式布局和remnant來(lái)解決移動(dòng)端的屏幕適配問(wèn)題meta標(biāo)簽
META標(biāo)簽,是在HTML網(wǎng)頁(yè)源代碼中一個(gè)重要的html標(biāo)簽。META標(biāo)簽用來(lái)描述一個(gè)HTML網(wǎng)頁(yè)文檔的屬性,例如作者、日期和時(shí)間、網(wǎng)頁(yè)描述、關(guān)鍵詞、頁(yè)面刷新等
作用
META標(biāo)簽是HTML標(biāo)記HEAD區(qū)的一個(gè)關(guān)鍵標(biāo)簽,它位于HTML文檔的和之間(有些也不是在和 之間)。它提供的信息雖然用戶(hù)不可見(jiàn),但卻是文檔的最基本的元信息。除了提供文檔字符集、使用語(yǔ)言、作者等基本信息外,還涉及對(duì)關(guān)鍵詞和網(wǎng)頁(yè)等級(jí)的設(shè)定
參考
手機(jī)端頁(yè)面自適應(yīng)解決方案—rem 布局進(jìn)階版
移動(dòng)端Web頁(yè)面適配方案
vh,vw單位你知道多少?
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/104325.html
摘要:最初產(chǎn)生這個(gè)項(xiàng)目的想法應(yīng)該是在年月份,當(dāng)時(shí)正在學(xué)習(xí)中,就萌生了這樣一個(gè)想法從一個(gè)用戶(hù)這一年發(fā)布的微博數(shù)據(jù)中,提取最有意義的個(gè)關(guān)鍵詞。這些東西提交完就可以提交審核了,微博應(yīng)用審核的速度還算比較快的,一兩天基本差不多會(huì)審核完。 最初產(chǎn)生這個(gè)項(xiàng)目的想法應(yīng)該是在2018年10月份,當(dāng)時(shí)正在學(xué)習(xí)python中,就萌生了這樣一個(gè)想法:從一個(gè)用戶(hù)這一年發(fā)布的微博數(shù)據(jù)中,提取最有意義的top50個(gè)關(guān)鍵...
摘要:不努力不奮斗,可能就會(huì)在基層一輩子止步不前。不過(guò),只一句,如果你還在做這一行,還是一名程序猿媛,想走上坡路的你,也許我這到手的十幾家一線互聯(lián)網(wǎng)公司性能優(yōu)化項(xiàng)目實(shí)戰(zhàn)可能會(huì)對(duì)你有所幫助。 ...
摘要:實(shí)戰(zhàn)之微信錢(qián)包騰訊服務(wù)界面網(wǎng)格布局是讓開(kāi)發(fā)人員設(shè)計(jì)一個(gè)網(wǎng)格并將內(nèi)容放在這些網(wǎng)格內(nèi)。對(duì)于移動(dòng)端適配,不同的公司不同的團(tuán)隊(duì)有不同的解決方案。柵格系統(tǒng)用于處理頁(yè)面多終端適配的問(wèn)題。 grid實(shí)戰(zhàn)之微信錢(qián)包 騰訊服務(wù)界面 CSS3網(wǎng)格布局是讓開(kāi)發(fā)人員設(shè)計(jì)一個(gè)網(wǎng)格并將內(nèi)容放在這些網(wǎng)格內(nèi)。而不是使用浮動(dòng)制作一個(gè)網(wǎng)格,實(shí)際上是你將一個(gè)元素聲明為一個(gè)網(wǎng)格容器,并把元素內(nèi)容置于網(wǎng)格中。 移動(dòng)端頁(yè)面適配—...
閱讀 2322·2023-04-26 00:01
閱讀 809·2021-10-27 14:13
閱讀 1840·2021-09-02 15:11
閱讀 3392·2019-08-29 12:52
閱讀 542·2019-08-26 12:00
閱讀 2574·2019-08-26 10:57
閱讀 3416·2019-08-26 10:32
閱讀 2859·2019-08-23 18:29