爱上编程网

CSS自适应布局

  • 时间:2019-11-27 09:43 编辑:青柠小助手 来源:计算机/互联网 阅读:79284
  • 扫一扫,手机访问
摘要:CSS自适应布局

标签: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



技术交流学习或者有任何问题欢迎加群

编程技术交流群 : 154514123 爱上编程
Java技术交流群 : 6128790  Java

  • 全部评论(0)
最新发布的资讯信息
【数码/游戏/手机|网络游戏】some try on func swap about & and *(2019-12-06 18:04)
【数码/游戏/手机|网络游戏】“云小蜜”使用总结(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】测验6: 组合数据类型 (第6周)-程序题(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】Django大纲(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】自下而上语法分析(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】RocketMq安装(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】JVM内存和JVM调优(十)--总结(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】JVM-基本操作(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】如何用Jpype创建HashMap和ArrayList(2019-12-06 18:03)
【数码/游戏/手机|网络游戏】Pandas操作excel(2019-12-06 18:03)
展开