CSS3盒模型之box-sizing

2023-11-05 12:08
文章标签 模型 frontend css3 box sizing

本文主要是介绍CSS3盒模型之box-sizing,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

这些天在做一个手机端的页面,遇到了一些问题!首当其冲的就是盒子的溢出问题!大家都知道,手机的尺寸各异,各种型号的手机多得能闪瞎你们的眼睛,为了能 让这些设置更好的浏览我们的页面,我们已经不能固定页面的大小了。所以很多时候我们对于大小的设置都需要使用百分比,嗯,试试看吧!

    对于一个导航,我们初始是想这样:

代码如下:

css:

nav{ width 100% ; background #001125 ; overflow hidden }
nav a{ display block ; float left ; width 20% ; height 60px ; color #FFF ; text-align center ; font 16px / 60px  Microsoft YaHei; background #0A92CD }
nav a.p 1 { background : orange}
nav a.p 2 { background purple }
nav a.p 3 { background green }
nav a.p 4 { background blue }
nav a.p 5 { background gray }

 

效果如下:

嗯,看起来还是不错的!

但是,很显然,在实际开发过程中总是存在各种“但是”(比如,产品经理对设计师说:这样不好看,我们要背景一致,用竖线把它们分隔开来...由于是乎,设计师就把方案改了~ 结果,前端工程师就屁颠屁颠的改代码)

css:

 

nav{ width 100% ; background #001125 ; overflow hidden }
nav a{ display block ; float left ; width 20% ; height 60px ; border-right : 1px  solid  #001125 ; color #FFF ; text-align center ; font 16px / 60px  Microsoft YaHei; background #0A92CD }
nav a:last-child{ border-right none }

 

一段时间后...终于改好了!来看一下效果吧~

“帮助”你为什么没有跟你们兄弟站在一条战线上?

对啊,为什么呢?我翻资料,查找原因...我查...

原来:现代浏览器对于盒模型的解析引起的问题,它们不会将border和padding包含在width之内,所以,这里各自20%的宽度是不包括border-right:1px的,现在元素中20%*5+4px(4个border-right:1px,最后一个被nav a:last-child{border-right: none}去除了)当然就超过了父容器100%的宽度了,所以第一排已经容不下“帮助”了,它不得不孤独的自成一排。

那么,有什么办法可以让它们兄弟重新“团聚”呢?那就是我们今天的主角:box-sizing!只需要,在为所有兄弟设置box-sizing:border-box,就可以让它们合家团圆了!

css:

nav{ width 100% ; background #001125 ; overflow hidden }
nav a{ display block ; float left ; width 20% ; height 60px ; border-right : 1px  solid  #001125 ; color #FFF ; text-align center ; font 16px / 60px  Microsoft YaHei; background #0A92CD ;box-sizing:border-box}
nav a:last-child{ border-right none }

来看看是不是真的实现了呢?

那是必须的!




IE6以前的版本中,对盒模型的解析其实不需要设置border-box就已经是将border与padding包含在了width之内。所以,IE6以前版本的浏览器,在此前的dome中可能就已经没问题了。在我们开发的过程中会发现,有时候,如果对页面中的大区域进行设置时,将border、padding计算到width和height之内,反而更灵活。但W3C的 CSS2.1规范却规定了他们并不能被包含其中。所以才出现了刚才那样的问题。不过幸亏到了css3中引入了这个box-sizing的新属性,它具有 “content-box”和 “border-box”两个值。

box-sizing:content-box就是遵从之前CSS2.1的W3C标准,当它定义width和height时,宽度不包括border和padding。

box-sizing:border-box时便是能完美解决问题的包含其中的设置了!

这篇关于CSS3盒模型之box-sizing的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/349750

相关文章

Vue3 的 shallowRef 和 shallowReactive:优化性能

大家对 Vue3 的 ref 和 reactive 都很熟悉,那么对 shallowRef 和 shallowReactive 是否了解呢? 在编程和数据结构中,“shallow”(浅层)通常指对数据结构的最外层进行操作,而不递归地处理其内部或嵌套的数据。这种处理方式关注的是数据结构的第一层属性或元素,而忽略更深层次的嵌套内容。 1. 浅层与深层的对比 1.1 浅层(Shallow) 定义

大模型研发全揭秘:客服工单数据标注的完整攻略

在人工智能(AI)领域,数据标注是模型训练过程中至关重要的一步。无论你是新手还是有经验的从业者,掌握数据标注的技术细节和常见问题的解决方案都能为你的AI项目增添不少价值。在电信运营商的客服系统中,工单数据是客户问题和解决方案的重要记录。通过对这些工单数据进行有效标注,不仅能够帮助提升客服自动化系统的智能化水平,还能优化客户服务流程,提高客户满意度。本文将详细介绍如何在电信运营商客服工单的背景下进行

这15个Vue指令,让你的项目开发爽到爆

1. V-Hotkey 仓库地址: github.com/Dafrok/v-ho… Demo: 戳这里 https://dafrok.github.io/v-hotkey 安装: npm install --save v-hotkey 这个指令可以给组件绑定一个或多个快捷键。你想要通过按下 Escape 键后隐藏某个组件,按住 Control 和回车键再显示它吗?小菜一碟: <template

【 html+css 绚丽Loading 】000046 三才归元阵

前言:哈喽,大家好,今天给大家分享html+css 绚丽Loading!并提供具体代码帮助大家深入理解,彻底掌握!创作不易,如果能帮助到大家或者给大家一些灵感和启发,欢迎收藏+关注哦 💕 目录 📚一、效果📚二、信息💡1.简介:💡2.外观描述:💡3.使用方式:💡4.战斗方式:💡5.提升:💡6.传说: 📚三、源代码,上代码,可以直接复制使用🎥效果🗂️目录✍️

【前端学习】AntV G6-08 深入图形与图形分组、自定义节点、节点动画(下)

【课程链接】 AntV G6:深入图形与图形分组、自定义节点、节点动画(下)_哔哩哔哩_bilibili 本章十吾老师讲解了一个复杂的自定义节点中,应该怎样去计算和绘制图形,如何给一个图形制作不间断的动画,以及在鼠标事件之后产生动画。(有点难,需要好好理解) <!DOCTYPE html><html><head><meta charset="UTF-8"><title>06

Andrej Karpathy最新采访:认知核心模型10亿参数就够了,AI会打破教育不公的僵局

夕小瑶科技说 原创  作者 | 海野 AI圈子的红人,AI大神Andrej Karpathy,曾是OpenAI联合创始人之一,特斯拉AI总监。上一次的动态是官宣创办一家名为 Eureka Labs 的人工智能+教育公司 ,宣布将长期致力于AI原生教育。 近日,Andrej Karpathy接受了No Priors(投资博客)的采访,与硅谷知名投资人 Sara Guo 和 Elad G

Retrieval-based-Voice-Conversion-WebUI模型构建指南

一、模型介绍 Retrieval-based-Voice-Conversion-WebUI(简称 RVC)模型是一个基于 VITS(Variational Inference with adversarial learning for end-to-end Text-to-Speech)的简单易用的语音转换框架。 具有以下特点 简单易用:RVC 模型通过简单易用的网页界面,使得用户无需深入了

透彻!驯服大型语言模型(LLMs)的五种方法,及具体方法选择思路

引言 随着时间的发展,大型语言模型不再停留在演示阶段而是逐步面向生产系统的应用,随着人们期望的不断增加,目标也发生了巨大的变化。在短短的几个月的时间里,人们对大模型的认识已经从对其zero-shot能力感到惊讶,转变为考虑改进模型质量、提高模型可用性。 「大语言模型(LLMs)其实就是利用高容量的模型架构(例如Transformer)对海量的、多种多样的数据分布进行建模得到,它包含了大量的先验

图神经网络模型介绍(1)

我们将图神经网络分为基于谱域的模型和基于空域的模型,并按照发展顺序详解每个类别中的重要模型。 1.1基于谱域的图神经网络         谱域上的图卷积在图学习迈向深度学习的发展历程中起到了关键的作用。本节主要介绍三个具有代表性的谱域图神经网络:谱图卷积网络、切比雪夫网络和图卷积网络。 (1)谱图卷积网络 卷积定理:函数卷积的傅里叶变换是函数傅里叶变换的乘积,即F{f*g}

秋招最新大模型算法面试,熬夜都要肝完它

💥大家在面试大模型LLM这个板块的时候,不知道面试完会不会复盘、总结,做笔记的习惯,这份大模型算法岗面试八股笔记也帮助不少人拿到过offer ✨对于面试大模型算法工程师会有一定的帮助,都附有完整答案,熬夜也要看完,祝大家一臂之力 这份《大模型算法工程师面试题》已经上传CSDN,还有完整版的大模型 AI 学习资料,朋友们如果需要可以微信扫描下方CSDN官方认证二维码免费领取【保证100%免费