自適應(yīng)布局meta標(biāo)簽中viewport、content、width、initial-scale、minimum-scale、maximum-scale總結(jié)
一、先明白幾個(gè)概念
phys.width:
device-width:
一般我們所指的寬度width即為phys.width,而device-width又稱為css-width。
其中我們可以獲取phys.width即width通過(guò)document.documentElement.clientWidth
;而獲取css-width通過(guò) window.screen.width獲取。如iphone6的phys.width為750px,而css-width為375px。
二、明白一個(gè)瀏覽器默認(rèn)行為。
試想,瀏覽器如果把電腦端的980px的網(wǎng)頁(yè)展現(xiàn)在寬度為750px的iphone6手機(jī)屏上,勢(shì)必會(huì)放不下,手機(jī)端橫向會(huì)出現(xiàn)滾動(dòng)條,怎么阻止這種情況呢,很簡(jiǎn)單,瀏覽器默認(rèn)一個(gè)虛擬窗口,不同瀏覽器有不同的虛擬窗口寬度的默認(rèn)值如:safari iphone:980px;
opera:850px; Andriod webkit:800px;IE:974px;然后會(huì)把這個(gè)980px虛擬窗口裝進(jìn)寬度為750px的iphone6中,當(dāng)然這樣的話必須縮放,這就是為什么在手機(jī)中展現(xiàn)電腦端頁(yè)面沒(méi)有出現(xiàn)橫向滾動(dòng)條,而且字跡明顯變小的原因。
三、講解meta name= viewport content= width=device-width initial-scale=1 minimum-scale=1 maximum-scale=1
meta標(biāo)簽中,width有兩個(gè)含義,第一、width為phys.width,第二,width也為虛擬窗口的width。這樣就會(huì)有兩個(gè)結(jié)果:
1、此時(shí)的iPhone6的phys.width也變成了css-width即375px,我們可以通過(guò)document.documentElement.clientWidth獲取得到此時(shí)phys.width確實(shí)為375px。
2、如你設(shè)計(jì)的是375px的手機(jī)端頁(yè)面,此時(shí)的虛擬窗口的寬度也為375px,再裝進(jìn)phys.width為375px的手機(jī),當(dāng)然如設(shè)計(jì)稿一樣的效果,不會(huì)縮放,也不會(huì)出現(xiàn)橫向滾動(dòng)條。
四、對(duì)響應(yīng)式布局,媒體查詢的影響
@media only screen and (min-width: 350px) and (max-width: 480px){.....................}
如沒(méi)有meta標(biāo)簽,此時(shí)的width當(dāng)然即為phys.width,iPhone6就不會(huì)執(zhí)行上邊的括號(hào)里邊的代碼,但是有了meta標(biāo)簽以后呢,width變成了css-width,即為375px,,所以是會(huì)執(zhí)行代碼的。
五、論meta標(biāo)簽的影響
從上邊可以看出,有了meta標(biāo)簽以后,原本的iPhone6,即像素比為2的手機(jī),可以按照css-width相同的像素比為1的手機(jī)一樣正常顯示,像素比更高的手機(jī)也能正常顯示。當(dāng)然現(xiàn)在andriod的2K屏在meta標(biāo)簽的幫助下也能正常顯示。即對(duì)于開(kāi)發(fā)者來(lái)說(shuō),已經(jīng)可以不管手機(jī)的像素比,只需按照css像素編寫(xiě)代碼即可。
參考鏈接: http://www.dbjr.com.cn/article/121531.htm
參考鏈接: http://www.dbjr.com.cn/article/121524.htm
以上就是這篇文章的全部?jī)?nèi)容了,希望本文的內(nèi)容對(duì)大家的學(xué)習(xí)或者工作能帶來(lái)一定的幫助~如果有疑問(wèn)大家可以留言交流,謝謝大家對(duì)腳本之家的支持!
- 解決PhoneGap不支持viewport的幾種方法
- 深入理解移動(dòng)前端開(kāi)發(fā)之viewport
- 詳解jquery插件jquery.viewport.js學(xué)習(xí)使用方法
- 關(guān)于meta viewport中target-densitydpi屬性詳解(推薦)
- 通過(guò)viewport實(shí)現(xiàn)jsp頁(yè)面支持手機(jī)縮放
- 關(guān)于viewport,Ext.panel和Ext.form.panel的關(guān)系
- ExtJs 學(xué)習(xí)筆記 Ext.Panle Ext.TabPanel Ext.Viewport
- 如何基于viewport vm適配移動(dòng)端頁(yè)面
相關(guān)文章
Javascript仿新浪游戲頻道鼠標(biāo)懸停顯示子菜單效果
這篇文章主要介紹了Javascript仿新浪游戲頻道鼠標(biāo)懸停顯示子菜單效果,涉及鼠標(biāo)事件及頁(yè)面元素結(jié)點(diǎn)的遍歷技巧,具有一定參考借鑒價(jià)值,需要的朋友可以參考下2015-08-08用javascript做一個(gè)小游戲平臺(tái) (二) 游戲選擇器
昨天晚上“設(shè)計(jì)”了n久,那些代碼都還沒(méi)有運(yùn)行起來(lái),有點(diǎn)心急、有點(diǎn)郁悶。2010-01-01js實(shí)現(xiàn)for循環(huán)跳過(guò)undefined值示例
這篇文章主要介紹了js實(shí)現(xiàn)for循環(huán)跳過(guò)undefined值,結(jié)合實(shí)例形式分析了js使用for循環(huán)針對(duì)數(shù)組的遍歷、判斷、運(yùn)算等相關(guān)操作技巧,需要的朋友可以參考下2019-07-07Javascript中獲取瀏覽器類型和操作系統(tǒng)版本等客戶端信息常用代碼
跟蹤一些最基本的客戶端訪問(wèn)信息,這里將一些公用的代碼總結(jié)下來(lái),需要的朋友可以參考下2016-06-06three.js創(chuàng)造時(shí)空裂縫特效實(shí)現(xiàn)示例
這篇文章主要為大家介紹了three.js創(chuàng)造時(shí)空裂縫特效實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11JavaScript數(shù)據(jù)分析之交集,并集,對(duì)稱差集
這篇文章主要介紹了JavaScript數(shù)據(jù)分析之交集,并集,對(duì)稱差集,文章圍繞主題展開(kāi)詳細(xì)的內(nèi)容介紹,具有一定的參考價(jià)值,需要的小伙伴可以參考一下2022-07-07vue-router路由懶加載的實(shí)現(xiàn)(解決vue項(xiàng)目首次加載慢)
這篇文章主要介紹了vue-router路由懶加載的實(shí)現(xiàn)(解決vue項(xiàng)目首次加載慢),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-08-08