国产xxxx99真实实拍_久久不雅视频_高清韩国a级特黄毛片_嗯老师别我我受不了了小说

資訊專欄INFORMATION COLUMN

移動屏幕適配

dreamGong / 3462人閱讀

摘要:簡介移動屏幕適配是一個比較令人頭疼的問題,這是我寫的一個通過動態(tài)設(shè)置的移動屏幕適配的工具函數(shù),包括定寬和兩種適配方法,目前在我自己的項目中用起來還不錯,后續(xù)也會優(yōu)化調(diào)整,地址這里。

2015-10-16更新。

簡介

移動屏幕適配是一個比較令人頭疼的問題,這是我寫的一個通過動態(tài)設(shè)置viewport的移動屏幕適配的工具函數(shù),包括定寬和rem兩種適配方法,目前在我自己的項目中用起來還不錯,后續(xù)也會優(yōu)化調(diào)整,github地址這里。

說明

頁面事先添加meta標(biāo)簽 ,然后調(diào)用方法如fixViewport("fixed", 640)即可。

參數(shù)

type
適配類型(可選值為"fixed"或"rem")

width
設(shè)計稿寬度(整數(shù))

適配方法

可以選擇以下兩種方式進(jìn)行屏幕適配:

定寬
原理:設(shè)定viewport的寬度為固定值(即傳遞的width值),并根據(jù)屏幕寬度和width值計算viewport縮放比例。
實際開發(fā)在css中任何長度尺寸均使用px單位,大小設(shè)置為設(shè)計稿中原始尺寸值;
字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。

rem:
原理:根據(jù)設(shè)備dpr和屏幕寬度來計算viewport寬度,并根據(jù)設(shè)備dpr計算viewport縮放比例,然后在html標(biāo)簽中設(shè)置font-size的屬性值。
實際開發(fā)在css中任何長度尺寸均使用rem單位,大小設(shè)置為設(shè)計稿中尺寸值 / 100;
字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。
若需要1px物理像素的邊框效果,則border的寬度不需要使用rem,設(shè)定為1px即可。

代碼
/**
 * Created by GG on 15/7/29.
 *
 *  頁面事先添加meta標(biāo)簽 
 *  參數(shù):type(適配類型, 可選值為"fixed"或"rem");width(設(shè)計稿寬度,整數(shù))
 *  可以選擇以下兩種情況適配:
 *  1. 定寬:原理是設(shè)定viewport的寬度為固定值(即傳遞的width值),并根據(jù)屏幕寬度和width值計算viewport縮放比例。
 *     實際開發(fā)在css中任何長度尺寸均使用px單位,大小設(shè)置為設(shè)計稿中原始尺寸值;
 *     字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
 *     非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。
 *  2. REM:原理是根據(jù)設(shè)備dpr和屏幕寬度來計算viewport寬度,并根據(jù)設(shè)備dpr計算viewport縮放比例,然后在html標(biāo)簽中設(shè)置font-size的屬性值。
 *     實際開發(fā)在css中任何長度尺寸均使用rem單位,大小設(shè)置為設(shè)計稿中尺寸值 / 100;
 *     字體單位使用em, body下直接子元素字體大小設(shè)置為設(shè)計稿中尺寸值 / 100;
 *     非直接子元素若其父元素未設(shè)置字體大小則與直接子元素相同,否則根據(jù)父元素字體大小計算其相對值。
 *     若需要1px物理像素的邊框效果,則border的寬度不需要使用rem,設(shè)定為1px即可。
 */

(function () {
    function fixViewport(type, designWidth) {
        var metaEl = document.querySelector("meta[name="viewport"]");
        //由于初始設(shè)置了viewport的width=device-width,所以此處docEl.clientWidth即是屏幕的設(shè)備寬度
        var clientWidth = document.documentElement.clientWidth;
        var width, scale;

        switch (type) {
            case "fixed":
                width = designWidth;
                scale = clientWidth / designWidth;
                break;
            case "rem":
                var dpr = window.devicePixelRatio || 1;
                width = clientWidth * dpr;
                scale = 1 / dpr;
                document.documentElement.style.fontSize = 100 * (clientWidth * dpr / designWidth) + "px";
                break;
        }
        metaEl.setAttribute("content", "width=" + width + ",initial-scale=" + scale + ",maximum-scale=" + scale +
            ",minimum-scale=" + scale);

        //設(shè)置body的基準(zhǔn)字體大小
        document.body.style.fontSize = 50 / scale + "px";
    }

    fixViewport("rem", 640);
}());

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://m.specialneedsforspecialkids.com/yun/85827.html

相關(guān)文章

  • 移動適配移動Web怎么做屏幕適配(一)

    摘要:屏幕適配是一個很容易被忽略的問題,但對于精益求精的產(chǎn)品而言,是必不可少的。對于開發(fā)的求職者而言,也是一個必需要理解清楚的經(jīng)典問題文啃先生壹移動端適配的是什么我們討論的是網(wǎng)頁適配多種尺寸屏幕,讓網(wǎng)頁效果看起來和設(shè)計師的設(shè)計稿一樣。 屏幕適配是一個很容易被忽略的問題,但對于精益求精的產(chǎn)品而言,是必不可少的。對于Web開發(fā)的求職者而言,也是一個必需要理解清楚的經(jīng)典問題 文 | 啃先生 Mar...

    huangjinnan 評論0 收藏0
  • 從零搭建移動H5開發(fā)項目實戰(zhàn)

    摘要:并且除了常用的端,還要考慮微信端,或者是端。所以我們要有一套機(jī)制,在端上走的代碼,在端或者微信端上走端對應(yīng)的代碼。對于一個從零開始的移動端項目,我總結(jié)了以上這些移動開發(fā)難點,希望之后的人能少踩點坑,站在我的肩膀上提高項目開發(fā)的效率和質(zhì)量。 從零搭建移動H5開發(fā)項目實戰(zhàn) 前端H5的前世今身 在Pc的時代,前端技術(shù)無疑統(tǒng)治了大多數(shù)用戶的交互界面!而在移動為王的今天,NA開發(fā)在早期占領(lǐng)了大多...

    terro 評論0 收藏0
  • 從零搭建移動H5開發(fā)項目實戰(zhàn)

    摘要:并且除了常用的端,還要考慮微信端,或者是端。所以我們要有一套機(jī)制,在端上走的代碼,在端或者微信端上走端對應(yīng)的代碼。對于一個從零開始的移動端項目,我總結(jié)了以上這些移動開發(fā)難點,希望之后的人能少踩點坑,站在我的肩膀上提高項目開發(fā)的效率和質(zhì)量。 從零搭建移動H5開發(fā)項目實戰(zhàn) 前端H5的前世今身 在Pc的時代,前端技術(shù)無疑統(tǒng)治了大多數(shù)用戶的交互界面!而在移動為王的今天,NA開發(fā)在早期占領(lǐng)了大多...

    pepperwang 評論0 收藏0
  • 移動 web 端屏幕適配 - rem

    摘要:前言最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動端屏幕適配這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動端屏幕適配的思考記錄下來。量得的高度為,因為在設(shè)計稿這樣尺寸的屏幕中,,所以該的的值為,即。 前言 最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動 web 端屏幕適配(rem)這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動 web 端屏幕適配(rem)的...

    Xufc 評論0 收藏0
  • 移動 web 端屏幕適配 - rem

    摘要:前言最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動端屏幕適配這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動端屏幕適配的思考記錄下來。量得的高度為,因為在設(shè)計稿這樣尺寸的屏幕中,,所以該的的值為,即。 前言 最近整理了一下以前學(xué)習(xí)前端的筆記,發(fā)現(xiàn)自己對移動 web 端屏幕適配(rem)這一塊并沒有真正理解,只是會用。接下來,把自己的一些對移動 web 端屏幕適配(rem)的...

    RdouTyping 評論0 收藏0

發(fā)表評論

0條評論

最新活動
閱讀需要支付1元查看
<