爱上编程网

CSS自适应布局

  • 时间:2019-11-27 09:43 编辑:青柠小助手 来源:计算机/互联网 阅读:79342
  • 扫一扫,手机访问
摘要: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

  • 全部评论(0)
最新发布的资讯信息
【数码/游戏/手机|网络游戏】画一棵漂亮的樱花树(不同种樱花+玫瑰+圣诞树喔)(2019-12-19 15:35)
【数码/游戏/手机|网络游戏】conda pip 安装 dgl 并运行demo 出现:Segmentation fault (core dumped) 错误(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】docker image换包步骤(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】Cron表达式(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】DRF单表序列化和反序列化(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】[LC] 287. Find the Duplicate Number(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】正则表达式常用匹配(2019-12-19 15:33)
【数码/游戏/手机|网络游戏】redis(2019-12-19 15:32)
【数码/游戏/手机|网络游戏】并发测试->countDownLatch(2019-12-19 15:32)
【数码/游戏/手机|网络游戏】console 打印消息时,可以使用 %c 指定随后的文本样式; %s 可引用参数变量。(2019-12-19 15:32)
展开