这几天学习了如何使用CSS,CSS给我的感觉就是,看似内容散乱,实则内涵规律。
因此我认为要学好CSS,多写代码,并适时地总结已学过的CSS,寻找和归纳出里面所蕴含的规律。
以下内容为我所归纳的知识点,若有错误,欢迎指出~
1.引入CSS三/四种方式
(1)style属性,内联样式,直接写在html标签后。
(2)style标签,通过在head处写style标签来实现同样的效果。
(3)新建外部CSS文件,<link rel="stylesheet" href="./xxx.css">
用link标签来引入外部CSS文件。
(4)(不常用)在CSS文件中引入另一个CSS,在第一个CSS文件开头处加入以下代码即可:@import url(./yyy.css);
2.float浮动
对标签进行float浮动后,要在其父亲元素上加入下列css代码,并声明class="clearfix"
.clearfix::after {
content: '';
display: block;
clear: both;
}
3.几种处理文本和背景的方式
text-decoration:none; /*去除文本下划线*/
list-style: none; /*去除文本原来的风格,例如文字前符号*/
font-weight: bold; /*字体加粗*/
background-position:center center;/*背景图居中*/
background-color:rgba(0,0,0,0.8);/*遮罩层透明度为0.8*/
background-size:cover;/*背景图大小自适应*/
4.<div>
div高度由其内部文档流元素的高度总和决定。
div高度由其内部文档流元素的高度总和决定。
div高度由其内部文档流元素的高度总和决定。
文档流是文档内元素的流动方向,
内联元素,从左往右流,因此加入border后,border在换行过程中会被断开,而不是形成两个独立的border。另外,在内联元素中输入一个长英文,长英文在换行时要整个单词换行,但可以通过在CSS中加入属性word-break:break-all;
来改变这种现象。
块级元素,每块占一行,从上往下流动。可以通过在CSS中加入display:inline-block;
来打破每块占一行的现象,但最好还是通过float和clearfix来实现。
CSS可以通过height来改变div块中文本框的大小。通过line-height来改变文字在文本框中的高度位置,且仅改变文字的高度位置,而不改变文本框位置和大小。通过使line-height等于height,可以让文本相对于文本框垂直居中。
5.<span>
span高度由建议行高来决定,但span中的建议行高很难通过文字解释(看笔记)
两个span标签中间可能会有许多看不见的东西,例如回车和空格,这些东西在展现的时候会统一变成一个空格。
内联元素不能通过CSS的width和height来改变文本框的大小,即不接受限制宽高,如果一定要改变,则要通过写入display:inline-block;
来实现。通过line-height能改变文字和文本框的高度,但不能使文字相对于文本框移动。
另:span标签里不能放div标签,否则会出bug。
6.脱离文档流的两种办法
(1)相对于窗口定位
positiong:fixed;
top:0;
left:0;
width:100%; /*加了此句非常容易出bug*/
fixed之后div会缩进,因此需要width:100%;
(2)子代相对于父代定位
position:relative; /*写于父代处*/
position:absolute;/*写于子代处*/
7.宽度的一些属性写法
(1)max-width:40px;
最大宽度为40px(会自适应)
(2)确定宽度的div自动居中
margin-left:auto;
margin-right:auto
8.自己理解盒模型的具体内容