div在网页四周留个等宽“包边”的办法

简介: div在网页四周留个等宽“包边”的办法

需求来了:

\

image.png

图片.png

easy,中间放个div,然后margin:20px即可,交差:

\

image.png

图片.png

感觉有点敷衍。思考下怎样蓝色边怎样才能都一样宽。js设置div的高度?不好,麻烦死了。

应该有css直接搞定的办法的。我想了下,把HTML、body、div统统高度100%,然后效果:

\

image.png

图片.png

底部咋回事捏?竟然产生滚动条了,要滚动下才能看到底部的蓝色:

\

image.png

图片.png

这肯定不行啊。分析下原因,应该是div设置100%高度后再margin:20px;就将div的整体高度硬生生又撑开了40px,于是只要往下延伸了。那么把高度设置为90%如何?看起来差不多了,但是这个方法不妥,因为和屏幕大小相关,其他屏幕看到的可能不是同等的蓝色宽度。突然想到box-sizing: border-box;这个方法,是不是能将margin缩到自己框里呢?但是看了下说明:

\

image.png

图片.png

它只管border和padding,而对于margin是无效的。

自己一时搞不定,于是请教同学,结果他给出个方案。直接div设置个border宽度20px,我大喊妙啊,我咋没想到,效果确实达到了:

\

image.png

图片.png

代码提炼了下如下:

<!DOCTYPE html>
<html>
<head>
    <title>div test</title>
    <style type="text/css">
        *{margin:0; padding:0;}
        html,body{height: 100%;}
        .test {height: 100%; border: 20px solid #00A0E9; box-sizing: border-box;}
    </style>
</head>
<body>
    <div class="test">fasdfasdf</div>
</body>
</html>

可是我不甘心,中觉得靠margin应该可以。于是我仔细思考:不就是上下一共多出来40px然后撑到底部么,如果我能把这40px减掉不就好了么?忽然脑海里删过个calc,这是css3.0中的一个函数,可以动态计算长度值。那么用height:calc(100% - 40px);即可,测试了下确实可以:

\

image.png

图片.png

不过看起来是一样了,但是上下滚动了下发现还是和border方案解决有点区别的,这个可以往下滚动一点点,虽然看不见滚动条,不知道是不是因为撑开然后又通过calc缩回去导致的,如果是那也是浏览器渲染的bug。代码如下:

<!DOCTYPE html>
<html>
<head>
    <title>div test</title>
    <style type="text/css">
        *{margin:0; padding:0;}
        html,body{height: 100%;}
        body{background:#00A0E9;}
        .test{height:calc(100% - 40px);margin:20px; background:#fff;}
    </style>
</head>
<body>
    <div class="test">fasdfasdf</div>
</body>
</html>

综上,还是用border的方案好。

目录
相关文章
【python】使用matplotlib绘图使刻度线向内
成功使用代码实现matplotlib绘制的图刻度线朝内
【python】使用matplotlib绘图使刻度线向内
语雀的markdown常用语法
语雀的markdown常用语法
8668 0
语雀的markdown常用语法
|
JavaScript 前端开发
vue3 保存二维码
vue3 保存二维码
534 0
|
监控 机器人 区块链
深度分析——狩猎者defi夹子机器人系统开发技术原理
过去一年的时间里,DeFi可谓是迅速崛起,发展态势极其迅猛。虽然DeFi尚处于发展早期阶段,但活跃度和参与度都呈指数地在增长。在DeFi中,交易被打包的顺序极大地影响了DeFi的经济利益。例如,在 UniSwap 中,同样两个针对某交易对的买单,先被执行的交易将获得更多代币。若你在一笔买单前买入同样的代币,然后又赶紧卖出,则将毫无风险的获利。
深度分析——狩猎者defi夹子机器人系统开发技术原理
vue+vant制作一个做题页面(包含选择题,判断题,填空题,简答题)
vue+vant制作一个做题页面(包含选择题,判断题,填空题,简答题)
1206 0
|
Linux 数据安全/隐私保护
|
移动开发 小程序 安全
对比多个笔记软件后,我选择了语雀
去年开始带团队,在面临团队文档管理共享软件选择时,我毫不犹豫的选择了语雀,语雀的协作功能非常出色。可以邀请团队成员加入我的笔记工作空间,共同协作编辑和维护笔记和文档。通过语雀,可以很方便地进行团队内部的协作和交流,并对笔记进行版本控制,以避免多人编辑时出现不同步的问题。通过团队空间、知识库、目录的层级管理,能很好的将知识做分类。
1375 0
|
Python
python十六进制怎么转换成十进制
python十六进制怎么转换成十进制
744 0

热门文章

最新文章