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元素具有块状元素特点。
a{
display:block;
}
块级元素特点:
- 每个块级元素都从新的一行开始,并且其后的元素也另起一行(真霸道,一个块级元素独占一行)
- 元素的高度、宽度、行高以及顶和底边距都可以设置
- 元素宽度在不设置的情况下,是它本身父容器的100%(和父元素的宽度一直),除非设定一个宽度。
2.2内联元素
在html中,span,a,label,strong,em就是内联元素(行内元素)(inline)元素。当然块状元素也可以通过代码display:inline将元素设置为内联元素。
div{
display:inline;
}
内联元素特点:
- 和其他元素都在一行上;
- 元素的高度、宽度及顶部和底部边距不可设置;
- 元素的宽度就是它包含的文字或图片的宽度,不可改变
解决行内元素间隙bug问题
行内元素之间会产生间隙bug问题的场景:
1、当行内元素之间有“回车”、“tab”、“空格”时就会出现间隙。
如下代码:
<div>
<a>1</a>
<a>2</a>
<span>33333</span>
<span>44444</span>
<em>555555</em>
</div>
解决方法:
1、写在一行,之间不要有空格之类的符号。
<div>
<a>1</a><a>2</a><span>33333</span><span>44444</span><em>555555</em>
</div>
2、使用font-size:0
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
div{
border:2px solid red;
}
上面是缩写,分开写为:
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以内的内容。因此一个元素实际宽度为:
盒子的宽度=左边界+左边框+左填充+内容宽度+右填充+右边框+右边界。
测试用例:
<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包含
<!-- body{font-size:12pt;line-height:12pt} *{margin:0;padding:0;} -->
- 我们应该担心吗?人工智能现在可以通过交谈来学习新单词!
- 印度财政部:比特币是纯粹投机行为 区块链资产是“庞氏骗局”
- 法律人工智能实验室成立,法官和律师会丢饭碗吗?
- 让GridView中CheckBox列支持FireFox
- 在ASP.NET MVC中通过URL路由实现对多语言的支持
- AI加持下的假肢将会越来越聪明
- 通过几个Hello World感受.NET Core全新的开发体验
- ASP.NET MVC三个重要的描述对象:ControllerDescriptor
- 基于自制数据集的MobileNet-SSD模型训练
- .NET Core采用的全新配置系统[1]: 读取配置数据
- ASP.NET MVC三个重要的描述对象:ActionDescriptor
- 升级比特币区块链后,以特币已叩响成功的大门
- .NET Core采用的全新配置系统[2]: 配置模型设计详解
- 采用双拼域名meicai.cn的美菜网融资4.5亿美元
- HTML 教程
- HTML 简介
- html div 标签介绍
- html span 标签介绍
- html a 超链接标签
- HTML Br换行标签介绍
- HTML P段落标签介绍
- HTML br与p标签区别
- Html H 标题标签
- html px em pt长度单位
- HTML form 标签
- HTML radio 单选框
- HTML B 加粗标签
- HTML strong加粗粗体标签
- HTML em 强调标签
- HTML i 斜体标签
- HTML u下划线标签
- HTML s 删除线标签
- Html img 图片标签
- Html上标注sup与下标注sub标签
- HTML nobr 禁止换行标签
- HTML hr 水平线标签
- HTML label 标签
- HTML input 标签
- HTML textarea 标签
- HTML select下拉列表标签
- HTML checkbox 多选框
- HTML font color 标签
- HTML iframe 框架标签
- HTML Table 表格
- HTML dl dt dd 标签
- HTML ol li有序列表标签
- HTML ul li 无序列表标签
- HTML 注释
- CSS 教程
- CSS 简介
- CSS 语法
- CSS Id 和 Class选择器
- CSS 样式的创建
- CSS background 背景介绍
- CSS 文本样式
- CSS font 字体
- CSS A 链接
- CSS ul ol列表样式
- CSS TABLE 样式
- CSS 框模型
- CSS border 边框
- CSS Outlines 轮廓
- CSS 外边距 Margin
- CSS Padding 内边距
- CSS 分组和嵌套选择器
- CSS 尺寸 (Dimension)
- CSS Display 属性
- CSS Position 定位
- CSS Float 浮动
- CSS 水平对齐(Horizontal Align)
- CSS 组合选择符
- CSS 伪类
- CSS 伪元素
- CSS 导航栏
- CSS 下拉菜单
- CSS 图片廊
- CSS 图像透明/不透明
- CSS sprite 图像拼合技术
- CSS 媒体类型
- CSS 属性选择器
- CSS 实例
- 聊聊dubbo-go的failfastCluster
- 一分钟学Python|Python的循环语句
- OpenCV4.4 中SIFT特征匹配调用演示
- 这些Python库虽然冷门,但功能真的很强大!
- SQL查找是否"存在",别再count了,很耗费时间的
- 采用 Vue 编写的功能强大的 Swagger-ui 页面
- SQL 计算中位数
- SQL 打印成绩单
- TypeScript 快速入门
- ES的新特性
- PHP设计模式|观察者模式
- JavaScript 中 this 的错误认识、绑定规则、常见问题讲解
- 实践:SpringBoot实现定时任务的动态增删启停
- Java并发编程的艺术[3]
- R语言 | 根据数据框的顺序进行筛选