关于盒模型的理解_html/css_WEB-ITnose
CSS中一个很重要的概念是盒模型,CSS处理网页时,它认为每个元素都包含在一个不可见的盒子里
由内容区域、内容区域周围的空间(内边距,padding)、内边距的外边缘(边框,border)和边框外面将元素与相邻元素隔开的不可见区域(外边距,margin)构成。具体如下图
浏览器中元素的宽度与其width属性值并不一致(除非没有内边距和边框)。CSS中的宽度指示的是内边距里内容区域的宽度,而在浏览器中显示宽度则是内容宽度、左右内边距和左右边框的总和,显示高度与之类似。
当使用了box-sizing:border-box;则元素的显示宽度就等于width属性的值。内容宽度、内边距和边框都包含在里面。如下图
看起来似乎是CSS设置的宽度变大了,但其实,更改的并不是CSS,改变的是浏览器对于宽度的计算,我们来看一个例子:
<!DOCTYPE html><html><head> <title>Test</title> <link rel="stylesheet" type="text/css" href="css/test.css"></head><body> <div class="box"></div></body></html>
.box{ border: 20px solid rgb(255,189,200); padding: 20px; height: 100px; width: 100px; background: rgb(160,197,232);}
效果:
宽度和高度都为180px,即20+20+100+20+20 = 180px,而内容区域一样是100px,加上box-sizing:border-box之后:
宽度和高度为100px,而内容区域只剩下20px,即100 - 20 - 20 - 20 - 20 = 20px
即当加上box-sizing:border-box之后,浏览器对于CSS中设置的width的计算方式变成了:border-left + padding-left + content + padding-right + border-right的总宽度,对于height的计算变成了:border-top + padding-top + content + padding-bottom + border-bottom的总高度
关于盒模型中border的应用:
制作小三角形:
最终效果:
示例:
<!DOCTYPE html><html><head> <title>Test</title> <link rel="stylesheet" type="text/css" href="css/test.css"></head><body> <div class="box"></div></body></html>
.box{ border: 100px solid rgb(255,189,200);/* 使用:after伪类的时候可以不添加solid,使用content的内容可保证小三角出现 */ border-top-color: #333; border-left-color: #7fc; border-bottom-color: #f4c; height: 0px; width: 0px;}
解释:
盒模型中,margin,border,padding都可以分成上、下、左、右四个部分,都可以进行分别控制,而当我们把padding和content的大小都设为0,而border给定宽度时,将会出现如上图所示的图形。我们也可以试试给定padding和content部分空间时的形态:
.box{ border: 100px solid rgb(255,189,200); border-top-color: #333; border-left-color: #7fc; border-bottom-color: #f4c; padding: 20px; /* 给予padding部分空间 */ height: 20px; /* 给予content部分空间 */ width: 20px;}
效果:
简单应用:
<!DOCTYPE html><html><head> <title>Test</title> <link rel="stylesheet" type="text/css" href="css/test.css"></head><body> <div class="box"> <ul> <li>Item 1</li> <li>Item 2</li> <li>Item 3</li> </ul> </div></body></html>
.box{ background: #2b2b2b; border-radius: 5px 5px; padding: .5em 0 .9375em .9375em; position: absolute; width: 222px;}.box:after{ border: solid transparent; border-top-color: #2b2b2b; border-width: 15px; content: " "; height: 0; left: 50%; margin-left: -15px; position: absolute; top: 99.9%; width: 0;}li{ color: white;}
效果:
以上只是个人粗浅理解,有啥问题,大家可以提出,一起探讨!

Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

Notepad++7.3.1
Easy-to-use and free code editor

SublimeText3 Chinese version
Chinese version, very easy to use

Zend Studio 13.0.1
Powerful PHP integrated development environment

Dreamweaver CS6
Visual web development tools

SublimeText3 Mac version
God-level code editing software (SublimeText3)

Hot Topics











The roles of HTML, CSS and JavaScript in web development are: 1. HTML defines the web page structure, 2. CSS controls the web page style, and 3. JavaScript adds dynamic behavior. Together, they build the framework, aesthetics and interactivity of modern websites.

The future trends of HTML are semantics and web components, the future trends of CSS are CSS-in-JS and CSSHoudini, and the future trends of JavaScript are WebAssembly and Serverless. 1. HTML semantics improve accessibility and SEO effects, and Web components improve development efficiency, but attention should be paid to browser compatibility. 2. CSS-in-JS enhances style management flexibility but may increase file size. CSSHoudini allows direct operation of CSS rendering. 3.WebAssembly optimizes browser application performance but has a steep learning curve, and Serverless simplifies development but requires optimization of cold start problems.

HTML is the cornerstone of building web page structure. 1. HTML defines the content structure and semantics, and uses, etc. tags. 2. Provide semantic markers, such as, etc., to improve SEO effect. 3. To realize user interaction through tags, pay attention to form verification. 4. Use advanced elements such as, combined with JavaScript to achieve dynamic effects. 5. Common errors include unclosed labels and unquoted attribute values, and verification tools are required. 6. Optimization strategies include reducing HTTP requests, compressing HTML, using semantic tags, etc.

The future of HTML is full of infinite possibilities. 1) New features and standards will include more semantic tags and the popularity of WebComponents. 2) The web design trend will continue to develop towards responsive and accessible design. 3) Performance optimization will improve the user experience through responsive image loading and lazy loading technologies.

The roles of HTML, CSS and JavaScript in web development are: HTML is responsible for content structure, CSS is responsible for style, and JavaScript is responsible for dynamic behavior. 1. HTML defines the web page structure and content through tags to ensure semantics. 2. CSS controls the web page style through selectors and attributes to make it beautiful and easy to read. 3. JavaScript controls web page behavior through scripts to achieve dynamic and interactive functions.

HTML, CSS and JavaScript are the core technologies for building modern web pages: 1. HTML defines the web page structure, 2. CSS is responsible for the appearance of the web page, 3. JavaScript provides web page dynamics and interactivity, and they work together to create a website with a good user experience.

HTMLisnotaprogramminglanguage;itisamarkuplanguage.1)HTMLstructuresandformatswebcontentusingtags.2)ItworkswithCSSforstylingandJavaScriptforinteractivity,enhancingwebdevelopment.

The article discusses the differences between HTML tags , , , and , focusing on their semantic vs. presentational uses and their impact on SEO and accessibility.
