網上關於這方面的文章有很多,重復的東西本文不再贅述,僅提供思路,並解釋一些其他文章講述模糊的地方。
轉自:http://jingyan.baidu.com/article/656db918949b59e381249ce1.html
1、使用meta標簽,這也是普遍使用的方法,理論上講使用這個標簽是可以適應所有尺寸的屏幕的,但是各設備對該標簽的解釋方式及支持程度不同造成了不能兼容所有瀏覽器或系統。
首先解釋該標簽的含義:
<meta name="viewport" content="width=device-width,initial-scale=1.0, minimum-scale=1.0, maximum-scale=1.0, user-scalable=no"/>
如果你完全不了解這個標簽的使用需要先百度一下。
解釋:content中的“width” 這個width指的是什么寬度,我看過的文章對這個都沒有解釋的很清楚,有幾個備選:虛擬窗口的寬度、手機屏幕的寬度、還是頁面的寬度等等?經試驗這個指的是虛擬窗口的寬度。了解寬度之后,對后續的各種scale,就應該知道是誰與誰的比例,是 虛擬窗口寬度 / 頁面寬度,這樣就會有問題出現安卓設備尺寸差異很大光主流的就有寬度為 320 480 720 1080 等各種尺寸而以上標簽只能支持一種尺寸,當然有些瀏覽器會自動縮放使其適應屏幕,但這不是統一標准,正確的做法是用js動態生成此標簽,當然,應該先獲取屏幕尺寸。
對於此標簽還有以下需要分享:
1)、user-scalable=no就一定可以保證頁面不可以縮放嗎?NO,有些瀏覽器不吃這一套,還有一招就是minimum-scale=1.0, maximum-scale=1.0 最大與最小縮放比例都設為1.0就可以了。
2)、initial-scale=1.0 初始縮放比例受user-scalable控制嗎?不一定,有些瀏覽器會將user-scalable理解為用戶手動縮放,如果user-scalable=no,initial-scale將無法生效。
3)、手機頁面可以觸摸移動,但是如果有需要禁止此操作,就是頁面寬度等於屏幕寬度是頁面正好適應屏幕才可以保證頁面不能移動。
4)、如果頁面是經過縮小適應屏幕寬度的,會出現一個問題,當文本框被激活(獲取焦點)時,頁面會放大至原來尺寸。
以上是使用viewport標簽的一些小體會,分享給大家。
2、第二種自適應屏幕尺寸的方法是將頁面做成980寬度,在沒有viewport標簽的情況下,移動設備屏幕范圍會顯示頁面980的寬度,如果頁面大於980,則在屏幕范圍內顯示頁面一部分,如果頁面小於980,則頁面居中兩側顯示空白,那么你猜,如果頁面寬度等於980會出現什么情況呢?
3、百分比法,首先應明確一個概年,CSS中的百分比中的百指的是什么,我告訴你指的是父元素,所有百分比都是這樣的。子元素寬度50%,那么父元素的寬度就是百,子元素的padding-left:50%,父元素的寬度是百,子元素的margin-top:20%,那么父元素的高是百。所以body默認寬度是屏幕寬度(PC中指的是瀏覽器寬度)子孫元素按百分比定位(或指定尺寸)就可以了,這只適合布局簡單的頁面,復雜的頁面實現很困難。
4、使用css3單位rem,有人這樣解釋rem,root-em,就是根部的em,想必em大家都懂的,那么rem就是將根節點html的font-size的值作為整個頁面的基准尺寸,默認html的font-size是16px,即1rem=16px,如果某div寬度為32px你可以設為2rem。當我們把html的font-size設為20px時,1rem=20px,那么32px=1.6rem了。到這里我們也就了解了rem的用法了,那么怎么用rem來實現不同尺寸屏幕的自適應呢?在頁面載入開始時首先判斷window的寬度(是window的寬度($(window).width()),不是屏幕分辯率的寬度(screen.width),兩者的差別請自行查閱),假設寬度為W,一個div在寬度為640px的設計稿的下的寬度為dW1,這樣如果html的font-size為100px,那么這個div的寬度用rem表示是多少呢?計算:div寬度dW2=dW1/100,px與rem之間很好換算,除以100就可以,這是假定屏幕寬度為640的,而不同寬度的屏幕怎么處理,為了能保證換算容易那就要為html設置一個合適的font-size,計算:100 / 640 = fontSize / W, fontSize = W / 640 * 100 = W / 6.4;
解釋一下為什么把100作為一個縮放比例,用10或1不是更方便嗎,這是因為大多數瀏覽器font-size的最小值為12px,所以只能用100了。
5、媒體查詢,媒體查詢也是css3的方法,我們要解決的問題是適應手機屏幕,這個媒體查詢正是為解決這個問題而生,媒體查詢的功能就是為不同的媒體設置不同的css樣式,這里的“媒體”包括頁面尺寸,設備屏幕尺寸等,比如我們要為寬度小於480px的頁面中的class="icon"的元素設置樣式,可以這樣寫,@media screen and (max-width=480px) {.icon{ some styles }};這里僅介紹這種思路,關於媒體查詢的詳細用法請參閱css手冊。
之前介紹一篇文章是:響應式web實戰總結 已經介紹了一些知識點,這里就不多介紹了;我們這邊來了解下如何使用媒體查詢寫不同的css樣式;針對響應式web設計開發,使用媒體查詢來適應不同的手機屏幕樣式開發時,我們需要寫不同的樣式,為此我們來分享下我個人開發響應式web頁面的經驗;針對目前手機的獨立像素有320,360,384,400,還有iphone6+是414的獨立像素,因此我們只需要針對目前這幾種匹配即可;如下:
- 針對手機獨立像素是360 ~399等屏幕的寬度
/*
* 但是邊距 字體大小等還是安裝360px來計算
*/
@media (min-width:360px) and (max-width: 399px) {}
2. 針對手機獨立像素是320~359之間的
/* min-width:320px
* 針對設備獨立像素為320px 的css
* min-width:320 和 max-width:359之間
*/
@media (min-width: 320px) and (max-width:359px){}
3. 針對設備獨立像素為400px以上的樣式。
/*
* 針對設備獨立像素為400px,邊距等等都按400px來計算
*/
@media (min-width: 400px) and (max-width:450px){}
4. 針對設備獨立像素為640px ~ 999px的css
/* min-width:640px
* 針對設備獨立像素為640px 的css
* min-width:640 和 max-width:999之間
* 邊距等按640px來計算
*/
@media (min-width: 640px) and (max-width:999px){}
5. 但是在PC端,我們為了適應PC端,所以針對寬度為1000以上也做一個顯示處理。
/* 最小寬度1000樣式
*為了適應PC端 所以PC端在設計時候 默認以1000px來設計的
*/
@media screen and (min-width:1000px) {}
一:使用rem來設置字體
為了方便計算字體,我們來設置瀏覽器10px,我們都知道瀏覽器默認的像素是16px,因此我們需要對html{font-size:62.5%;} // 10 / 16 = 62.5%;
首先假如設計搞在移動端上是按照750px設計稿上的話,假如字體在750px下字體大小我們使用rem來寫大小;那么他們的字體大小在各個獨立像素下如下計算:
- 針對設備獨立像素為640px ~ 999px的css
@media (min-width:640px) and (max-width: 999px) {
/* 750/640 = 1.17*/
html{font-size: 53.42%;} /*62.5% / 1.17 */
}
@media (min-width: 400px) and (max-width:450px){
/* 750 / 400 = 1.875 */
html{font-size:33.33% } /* 62.5% / 1.875 */
}
@media (min-width:360px) and (max-width: 399px) {
/* 750 / 360 = 2.08 */
html{font-size:30%} /* 62.5% / 2.08 */
}
@media (min-width: 320px) and (max-width:359px){
/* 750/320 = 2.34 */
html{font-size: 26.7%} /* 62.5 / 2.34 */
}
二: 針對寬度,高度,background-size, margin及padding的計算方法;
假如在750px下的寬度是132px;高度是132px;background-size:132px 132px; margin:20px;Padding:20px;
針對設備獨立像素為640px ~ 999px的css
@media (min-width:640px) and (max-width: 999px) {
/* 750/640 = 1.17*/
html{font-size: 53.42%;} /*62.5% / 1.17 */
// 下面的屬性都是 本身的像素 / 1.17 得來的
width: 112.82px; // 132 / 1.17
height:112.82px; // 132 / 1.17
background-size:112.82px 112.82px; // 132 / 1.17
margin:17.09px; // 20 / 1.17
padding:17.09px; // 20 / 1.17
}
@media (min-width: 400px) and (max-width:450px){
/* 750 / 400 = 1.875 */
html{font-size:33.33% } /* 62.5% / 1.875 */
// 下面的屬性都是 本身的像素 / 1.875 得來的
width: 70.4px; // 132 / 1.875
height: 70.4px; // 132 / 1.875
background-size: 70.4px 70.4px; // 132 / 1.875
margin:10.67px; // 20 / 1.875
padding: 10.67px; // 20 / 1.875
}
@media (min-width:360px) and (max-width: 399px) {
/* 750 / 360 = 2.08 */
html{font-size:30%} /* 62.5% / 2.08 */
// 下面的屬性都是 本身的像素 / 2.08 得來的
width: 63.46px; // 132 / 2.08
height: 63.46px; // 132 / 2.08
background-size: 63.46px 63.46px; // 132 / 2.08
margin:9.62px; // 20 / 2.08
padding: 9.62px; // 20 / 2.08
}
@media (min-width: 320px) and (max-width:359px){
/* 750/320 = 2.34 */
html{font-size: 26.7%} /* 62.5 / 2.34 */
width: 56.41px; // 132 / 2.34
height: 56.41px; // 132 / 2.34
background-size: 56.41px 56.41px; // 132 / 2.34
margin:8.55px; // 20 / 2.34
padding: 8.55px; // 20 / 2.34
}
但是有時候在小屏幕下字體太小了,使用戶看起來太吃力,我們可以針對小屏幕下適當掉大一點即可;