css学习--css基础
学习慕课网笔记,课程:http://www.imooc.com/code/2024
1.css选择器
子选择器:parent>child
子选择器是指选择parent的范围内的第一个子元素。这里parent和child均是伪代码。可以是class用.classname,也可以是标签ul>li,也可以是id #pid>#cid
后代选择器:parent child
后代选择器是指:选择parent范围内的所欲child元素。与子选择器不同的是,这里包含嵌套内的child元素,而子选择器仅仅选中parent下的直接的第一个子元素。
全局选择:*{}
这里可以配置全局的默认配置,如去掉默认间距等。
多个选择器同时设置:h,span,div{}
多个选择器用逗号间隔,设置通用的样式。
2.元素分类
在css中,html中的标签元素大体被分为三种不同的类型:块状元素、内联元素(又叫行内元素)和内联块状元素。
常用的块状元素有:
div,p,h1..h6,ol,ul,dl,table,address,blockquote,form
常用的内联元素有:
a,span,br,i,em,strong,label,q,var,cite,code
常用的内联块状元素有:
img,input
2.1块级元素
什么是块级元素?在html中div,p,hl,form,ul,li就是块级元素。设置display:block就是将元素显示为块级元素。如下代码就是将内联元素a转换为块级元素,从而使a元素具有块状元素特点。
1 2 3 | a{ display:block; } |
块级元素特点:
- 每个块级元素都从新的一行开始,并且其后的元素也另起一行(真霸道,一个块级元素独占一行)
- 元素的高度、宽度、行高以及顶和底边距都可以设置
- 元素宽度在不设置的情况下,是它本身父容器的100%(和父元素的宽度一直),除非设定一个宽度。
2.2内联元素
在html中,span,a,label,strong,em就是内联元素(行内元素)(inline)元素。当然块状元素也可以通过代码display:inline将元素设置为内联元素。
1 2 3 | div{ display:inline; } |
内联元素特点:
- 和其他元素都在一行上;
- 元素的高度、宽度及顶部和底部边距不可设置;
- 元素的宽度就是它包含的文字或图片的宽度,不可改变
解决行内元素间隙bug问题
行内元素之间会产生间隙bug问题的场景:
1、当行内元素之间有“回车”、“tab”、“空格”时就会出现间隙。
如下代码:
1 2 3 4 5 6 7 | < div > < a >1</ a > < a >2</ a > < span >33333</ span > < span >44444</ span > < em >555555</ em > </ div > |
解决方法:
1、写在一行,之间不要有空格之类的符号。
1 2 3 | < div > < a >1</ a >< a >2</ a >< span >33333</ span >< span >44444</ span >< em >555555</ em > </ div > |
2、使用font-size:0
1 2 | div{font-size:0;} a,span,em{font-size:16px;} |
网上还有很多有趣的方法可解决这个bug感兴趣的小伙伴们快去搜索一下吧。
2.3内联块状元素
内联块状元素(inline-block)就是同时具备内联元素、块状元素的特点,代码display:inline-block就是将元素设置为内联块状元素(css2.1)img,input标签就是这种内联块状状态标签。
inline-block元素特点:
- 和其他元素都在一行上;
- 元素的高度、宽度、行高以及顶和底边距都可以设置;
3.盒子模型
3.1什么是盒子模型
css中,盒子模型是关于元素的宽高的。如下图:
- content:内容,它可以是文字、图片等
- padding:内编剧,空白,填充,从内容到边框的距离
- border:边框,边框的宽度和样式
- margin:外编剧,边界
3.2边框
盒子模型的边框就是围绕着内容及补白的线,这条线你可以设置它的粗细、样式和颜色。
如下代码设置div
1 2 3 | div{ border:2px solid red; } |
上面是缩写,分开写为:
1 2 3 4 5 | div{ border-width:2px; border-style:solid; border-color:red; } |
注意:
- border-style(边框样式)常见样式:dashed(虚线)|dotted(点线)|solid(实线)
- border-color(边框颜色)中的颜色可设置为十六进制颜色,如:#888
- border-width(边框宽度)中宽度也可以设置为:thin|medium|thick(不常用),最常用的是像素(px)
边框方向:
如果想单独设置下边框,可以:div{border-bottom:1px solid red;}
同样可以设置其他三边:
border-top:1px solid red;border-right:1px solid red;border-left:1px solid red;
3.3盒模型的宽度和高度
css内定义的宽width和高height指的是填充padding以内的内容。因此一个元素实际宽度为:
盒子的宽度=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界。
测试用例:
1 2 3 4 5 6 7 8 9 10 11 | < style type="text/css"> #div_id{ width: 200px; padding: 20px; border: 1px solid red; margin: 10px; } </ style > < div id="div_id"> 盒模型测试用例 </ div > |
结果:
3.4盒模型填充
元素内容与边框之间可以设置距离,叫做padding(填充)。填充也可以分上右下左。如下:
div{padding:20px 10px 15px 30px;}
顺序不要搞错!分开写:
div{padding-top:20px;padding-right:10px;padding-bottom:15px;padding-left:30px;}
如果上右下左都填充为10px可以这么写:
div{padding:10px;}
如果上下填充为10px,左右填充为20px:
div{padding:10px 20px;}
3.5盒模型边界
元素与其他元素之间的距离可以使用边界margin来设置。边界同样分上右下左。
4.布局
css包含
关注我的公众号

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
· 分享4款.NET开源、免费、实用的商城系统
· 全程不用写代码,我用AI程序员写了一个飞机大战
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· 记一次.NET内存居高不下排查解决与启示
· 白话解读 Dapr 1.15:你的「微服务管家」又秀新绝活了