码迷,mamicode.com
首页 > Web开发 > 详细

CSS自适应布局

时间:2019-11-19 17:16:02      阅读:112      评论:0      收藏:0      [点我收藏+]

标签:java   offset   content   pre   color   ||   导出   dde   remove   

目标效果:

技术图片

缩小浏览器之后

技术图片

 

在<head>最前面引入flexible.js

<head>
 。。。
<script type="text/javascript" src="./lib/flexible.js"></script>
。。

</head>
flexible.js 内容如下

 

(function flexible (window, document) {
    var docEl = document.documentElement
    var dpr = window.devicePixelRatio || 1
    // adjust body font size
    // console.log(dpr)
    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
        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))

然后根据当前浏览器宽度: 2048px = 10rem 推导出204.8px = 1rem 。对所有标签宽高,字体用到px的地方,换算成rem即可

> screen.width
< 2048

??根据你当前的浏览器宽度来换算

 

例如:

.div{
  width:204.8px;
  height:204.8px;         
}

转算成

.div{
  width:1rem;
  height:1rem;         
}

 

参考资料:http://caibaojian.com/simple-flexible.html 

CSS自适应布局

标签:java   offset   content   pre   color   ||   导出   dde   remove   

原文地址:https://www.cnblogs.com/liuw-flexi/p/11890502.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!