vue cli3適配全部端方案

應用場景

頁面須要在pc端和移動端同時兼容,之前個人方案都是使用媒體查詢來判斷當前設備大小,而後寫兩套或者三套css代碼來兼容他們,能達到目的,而且效果不錯,可是感受仍是稍微麻煩了一丟丟。後面瞭解了一下flexable.js腳本,稍做修改,基本能夠知足個人需求。javascript

postcss-px2rem

yarn add postcss-px2rem

postcss-px2rem插件能夠將px轉爲rem,須要在vue.config.js(項目沒有的話就手動建立一個)中配置插件css

// css相關配置
    css: {
        // 啓用 CSS modules
        modules: false,
        // 是否使用css分離插件
        extract: true,
        // 開啓 CSS source maps?
        sourceMap: false,
        // css預設器配置項
        loaderOptions: {
            css: {},
            postcss: {
                plugins: [
                    //remUnit這個配置項的數值是多少呢??? 一般咱們是根據設計圖來定這個值,緣由很簡單,便於開發。
                    //假如設計圖給的寬度是750,咱們一般就會把remUnit設置爲75,這樣咱們寫樣式時,能夠直接按照設計圖標註的寬高來1:1還原開發。
                    require('postcss-px2rem')({
                        remUnit: 75
                    })
                ]
            }
        },
    }

flexible.js

flexible會爲頁面根據屏幕自動添加標籤,動態控制initial-scale,maximum-scale,minimum-scale等屬性的值 ===>設備縮放比

因此,在咱們的html的header中,就不要以前配置的viewport的meta標籤了html

<meta name="viewport"
        content="width=device-width, viewport-fit=cover, initial-scale=1, maximum-scale=1, minimum-scale=1, user-scalable=no">

這種標籤flexble會自動幫咱們加上。vue

下面附上修改完後的flexble腳本代碼:java

(function flexible (window, document) {
    var docEl = document.documentElement
    var dpr = window.devicePixelRatio || 1
    var isMobileDevice = /(iPhone|iPad|iPod|iOS|Android)/i.test(navigator.userAgent);
    dpr = isMobileDevice ? dpr : 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 () {
        let width = docEl.clientWidth
        // 下面5行爲本身加的代碼,pc端頁面不轉rem
        let remUnitConfig = 75
        let viewWidthMax = remUnitConfig * 10
        if (width / dpr > viewWidthMax) {
            width = viewWidthMax * dpr
        }

        var rem = width / 10
        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))

最後須要在index.html中引入腳本:
flexble.js要和index.html文件同級
image.png
最後在head添加js標籤,引入它:app

<script src="flexible.js" type="text/javascript" charset="utf-8"></script>

自此,項目就配置完了。post

相關文章
相關標籤/搜索