CSS学习笔记

 CSS-层叠样式表-网页实际上是一个多层的结构,通过CSS可以分别为网页的每一个层来设置样式,而最终我们能看到只是网页的最上边的一层-总之一句话,CSS用来设置网页中元素的样式

使用CSS来修改元素的样式

-第一种方式(内联样式/行内样式)不推荐使用:-在标签内部通过style属性来设置元素的样式-使用内联样式,样式只能对一个标签生效,多个标签同时使用时,不方便维护-注意:开发时绝对不要使用内联样式
-第二种方式(内联样式表):-将样式编写到head的style标签里,然后通过CSS选择器来选中元素并为其设置各种格式,可以为多个标签设置样式,并且只需要修改一处即可-内部样式表更加方便对样式进行复用-注意:内联样式表只能对一个网页起作用,它里面的样式不能跨网页复用
-第三种方式(外部样式表)最佳实践:-可以将CSS样式编写到一个外部的CSS文件中,然后通过link标签引入外部的CCS文件-外部样式表需要通过link标签来引人,意味着只要想使用这些样式的网页都可以对其进行引用,使样式可以在不同页面之间进行复用-将样式编写到外部的CSS文件中,可以使用到浏览器的缓存机制,从而加快网页的加载速度,提高用户体验

CSS的基本语法

-选择器:-通过选择器可以选中页面中的指定元素
-声明块:-   通过声明块来指定要为元素设置的样式-  声明块由一个一个的声明组成-  声明块时一个名值对结构,一个样式名对应一个样式值,名和值之间以: 连接,以; 结尾-常用选择器-元素选择器:作用:根据标签名来选中指定的元素语法:标签名{}例子:p{}  h1{}  div{}-id选择器:作用:根据元素的id属性值选中一个元素语法:#id属性值{}例子:#abc{}-class选择器是一个标签的属性,它和id类似,不同的是class可以重复使用,可以通过classs属性来为元素分组-通配选择器:作用:选中页面的所有元素语法:*-交集选择器:作用:选中同时复合多个条件的元素语法:选择器1选择器2选择器3...选择器n{}注意:交集选择器中的所有元素选择器,必须使用元素选择器开头例子:div.red{}-并集选择器(选择器分组):作用:同时选择多个选择器对应的元素语法:选择器1,选择器2,选择器3,...,选择器n{}例子:#abc,p,div.red{}-关系选择器父元素:直接包含了子元素的元素叫父元素子元素:直接被父元素包含的元素叫子元素祖先元素:直接或间接包含后代元素的元素叫祖先元素,一个元素的父元素也是它的祖先元素后代元素:直接或间接被祖先元素包含的元素叫后代元素,子元素也是后代元素兄弟元素:拥有相同父元素的兄弟元素-子元素选择器:作用:选中指定父元素的指定元素语法:父元素>子元素例子:div.red > span{}-后代元素选择器:作用:选中指定元素内的指定后代元素语法:祖先 后代例子:div span{}-兄弟元素选择器:-选择下一个兄弟语法:前一个 + 后一个例子:p + span{}-选择下面所有兄弟语法:兄 ~ 弟例子:p ~ span-属性选择器[属性名] 选择含有指定属性的元素[属性名=属性值] 选择含有指定属性和属性值的元素[属性名^=属性值] 选择属性值以指定值‘开头’的元素[属性名$=属性值] 选择属性值以指定值‘结尾’的元素[属性名*=属性值] 选择属性值中’含有某值‘的元素的元素-伪类选择器伪类(不存在的类,特殊的类)-伪类用来描述一个元素的特殊状态例如:一个子元素,被点击的元素,鼠标移入的元素...-伪类一般情况下都是使用: 开头:first-child 第一个子元素:last-child 最后一个子元素:nth-child() 选中第n个子元素特殊值:n(第n个)n的范围0到正无穷2n 或者 even 表示选中偶数位的元素2n+1 或者 odd 表示选中奇数位的元素-以上这些伪类都是根据所有的子元素进行排序:first-of-type:last-of-type:nth-of-type()-这几个伪类的功能和上述的类似,不通点是他们是在'同类型元素中'进行排序例如: ul > li:first-of-type-:not()否定伪类,将符合条件的元素从选择器中去除-a标签相关(超链接)的伪类-  a:link 用来表示没有访问过的链接(正常的链接)-   a:visited 用来表示访问过的链接由于隐私的原因,所以visited这个伪类只能修改链接的颜色- :hover 用来表示鼠标移入的状态-  :active 用来表示鼠标点击-伪元素伪元素表示页面中一些特殊的并不真实存在的元素(特殊位置)伪元素使用 :: 开头::first-letter 表示第一个字母::first-line 表示第一行::selection 表示选中的内容::before 元素的开始::after 元素的结束before和after 必须结合content属性来使用例如:div::before{content: "abc";}

选择器的权重:

样式的冲突:当我们通过不同的选择器,选中相同的元素,并且为相同的样式设置不同的值时,此时发生了样式的冲突。
发生样式冲突时,应用哪个样式由选择器的权重(优先级)决定选择器的权重:         优先级内联样式             1,0,0,0id选择器                0,1,0,0类和伪类选择器      0,0,1,0元素选择器            0,0,0,1通配选择器            0,0,0,0继承的样式            没有优先级比较优先级,需要将所有的选择器的优先级进行相加计算,最后优先级越高,则越优先显示(分组选择器是单独计算的)-选择器的累加不会超过其最大的数量级,类选择器再高不会超过id选择器(不会超过前一位)-如果优先级计算后相同,此时则优先使用靠下的样式可以在某一个样式的后面添加 !important,则此时该样式会获得到最高的优先级,甚至超过内联样式(注意:在开发中一点要慎用)-

继承

  1. 样式的继承,我们为一个元素设置的样式同时也会应用到它的后代元素上

  2. 继承是发生在祖先的后后代之间的

  3. 继承的设计是为了方便我们的开发,利用继承我们可以将一些通用的样式统一设置到共同的祖先元素上,这样只需设置一次就可以让所以元素继承样式

  4. 注意:并不是所有样式都会被继承:
    比如:背景相关的,布局相关等的这些样式都不会被继承。

像素和百分比

  1. 长度单位:像素(px)
    -屏幕(显示器)实际上上由一个一个的小点点构成的
    -不同屏幕的像素大小是不同的,像素越小的屏幕显示的效果越清晰
    -所以同样的200px在不同的设备下显示效果不一样

  2. 百分比:
    -也可以将属性值设置为相对于其父元素属性的百分比
    -设置百分比可以使子元素跟随父元素的改变而改变

  3. em:
    -em是相对于元素的字体大小来计算的
    -1em = 1front-size
    -em 会根据字体大小的改变而改变

  4. rem:
    -rem 相对于根元素的字体大小来计算的

RGB值

颜色单位:
在CSS中可以直接使用颜色名来设置各种颜色
- 比如:red,blue,yellow…
- 但是在CSS中直接使用颜色名是非常的不方便

RGB值:- RGB通过三种颜色的不同浓度来调配出不同的颜色- R red,  G green,  B blue- 每一种颜色的范围在0~255(0%~100%)之间- 语法:RGB( 红色,绿色,蓝色 )RGBA:- 就是在RGB的基础上增加了一个a表示不透明度- 需要四个值,前三个和rgb一样,第四个表示不透明度-   1表示完全不透明    0表示完全透明  .5表示半透明十六进制的RGB值:- 语法:#红色绿色蓝色- 颜色浓度通过 00-ff(最大)- 如果颜色两位两位重复可以进行简写,例如:#aabbcc --> #abcHSL值/HSLA值:- H 色相(0~360)- S 饱和度,颜色的浓度(0%~100%)- L 亮度,颜色的亮度(0%~100%)

文档流

文档流(normal flow)- 网页是一个多层的结构,一层夹着一层- 通过CSS可以分别为每一层来设置样式- 作为用户来讲只能看到最顶上一层- 这些层,最底下的一层称为文档流,文档流是网页的基础我们所创建的元素默认都是在文档流中进行排列- 对于我们来说,元素主要有两个状态:·在文档流中·不在文档流中(脱离文档流)- 元素在文档流中有什么特点?-块元素- 块元素会在页面中独占一行- 默认宽度是父元素的全部(会把父元素撑满)- 默认高度是被内容撑开(子元素)- 行内元素- 行内元素不会独占页面的一行,只占自身的大小- 行内元素在页面中自左向右水平排列,如果一行之中不能容纳下所有的行内元素,则元素会换到第二行继续自左向右排列(书写习惯一致)- 行内元素的默认宽度和高度都是被内容撑开

盒子模型

·盒模型、盒子模型、框模型(box model)- CSS将页面中的所有元素都设置成为一个矩形的盒子- 将元素设置为矩形的盒子后,对页面的布局将变成将不同的盒子摆放到不同的位置- 每一个盒子都有以下几个部分组成:1. 内容区(content)元素中的所有的子元素和文本内容都在内容区中排列内容区的大小由width和height两个属性来设置width:设置内容区的宽度height:设置内容区的高度2. 内边距(padding)3. 边框(border)边框属于盒子边缘,边缘里边属于盒子内部,出了边框都是盒子的外部(边框的大小会影响整个盒子的大小)要设置边框,需要至少设置三个样式:   边框的宽度 border-width边框的颜色 border-color边框的样式 border-style4. 外边距(margin)·盒子模型-边框-border-width:默认值:一般为3个像素border-width 可以用来指定四个方向的边框的宽度值的情况:四个值:上 右 下 左三个值:上 左右 下两个值:上下 左右一个值:上下左右除了border-width还有一组 border-xxx-width (xxx可以是top right bottom left-用来单独指定某一个边的宽度)-border-color:        border-color 用来指定边框的颜色,同样可以分别指定四个边的边框(规则和border-width一样)border-color也可以省略不下,如果省略了则自动使用color的颜色值-border-style:border-style指定边框的样式solid表示实线dotted表示点状虚线dashed表示虚线double表示双线border-style的默认值是none,表示没有边框-border简写属性,通过该属性可以同时设置边框所有的相关样式,并且咩呀顺序要求除了border意外还有四个 border-xxx (top, right, bottom, left )·盒子模型-内边距内边距(padding):  - 内容区和边距之间的距离是内边距padding:上 右 下 左- 一共有四个方向的内边距:padding-toppadding-rightpadding-bottompadding-left- 内边距的设置会影响到盒子的大小- 背景颜色会延伸到那边啥内边距上- 一个盒子的可见框的大小,可由内容区,内边距和边框共同决定所以在计算盒子大小时,还需要将这三个区域加到一起计算·盒子模型-外边距外边距(margin):- 外边距不会影响盒子可见框的大小- 但是外边距会影响盒子的位置- 一个有四个方向的外边距margin-top-上外边距,设置一个正值,元素会向下移动margin-right-默认情况下设置margin-right不会产生任何效果margin-bottom-下外边距,设置一个正值,其下边的元素会向下移动margin-left-左外边距,设置一个正值,元素会向右移动(margin也可以设置为负值,如果是负值则元素会向相反方向移动)-元素在页面中说按照自左向右的顺序排列的所以默认情况下如果我们设置的左和上外边距则会移动自身元素而设置右和下外边距会移动其他元素- margin的简写属性:margin 可以同时设置四个方向的外边距,用法和padding一样-margin 会影响到盒子实际占用的空间·盒子模型-水平方向的布局元素的水平方向的布局:元素在其父元素中水平方向的位置由以下几个属性共同决定:margin-leftborder-leftpadding-leftwidthpadding-rightborder-rightmargin-left一个元素在其父元素中,水平布局 ‘必须要满足’ 以下的等式:margin-left + border-left + padding-left + width + padding-right + border-right + margin-left = 其父元素内容区的宽度(必须满足)-以上等式必须满足,如果相加结果使等式不成立,则称为过度约束,则等式会自动调整-调整的情况:-如果这七个值中没有为auto的情况,则浏览器会自动调整margin-right的值使等式满足(当子元素宽度大于父元素宽度时,margin-right的值为负数)-这七个值中有三个值课设置为autowidthmargin-leftmargin-right-如果某个值为auto,则会自动调整为auto的那个值来使等式成立-如果将一个宽度和一个外边距设置为auto,则宽度会调整到最大,设置为auto的那个外边距会自动为0-如果将三个值都设置为auto,则外边距都是0,宽度最大-如果将两个两个外边距设置为auto,宽度固定值,则回将两个外边距设置为相同的值我们经常利用这个特点来使一个元素在其父元素中水平居中例子:margin: xxpx;margin: 0 auto;·盒子模型-垂直方向的布局-默认情况下父元素的高度被内容撑开- 子元素是父元素的内容区中排列的:如果子元素的大小超过了父元素,则子元素会从父元素中溢出使用 overflow 属性来设置父元素如何处理溢出的子元素可选值:visible:默认值 子元素会从父元素中溢出,在父元素外部的位置显示hidden:溢出内容将会被裁剪不会显示scroll:生成两个滚动条,通过滚动条来查看完成整内容auto:根据需要生成滚动条·盒子模型-外边距的重叠(折叠)-相邻的垂直方向外边距会发生重叠现象-兄弟元素-兄弟元素间的相邻垂直外边距会取两者之间的较大值(两者都是正值)-特殊情况:如果相邻的外边距一正一负,则取两者的和如果相邻的外边距都是负值,则取两者中绝对值较大的-兄弟元素之间的外边距的重叠,对于开发是有利的,所以我们不需要进行处理-父子元素- 父子元素之间相邻外边距,子元素的会传递给父元素(上外边距)- 父子外边距的折叠会影响到页面的布局,必须要进行处理·盒子模型-行内元素- 行内元素不支持设置宽度和高度- 行内元素可以设置padding,但是垂直方向padding不会影响页面的布局- 行内元素可以设置border,垂直方向的border不会影响页面的布局- 行内元素可以设置margin,垂直方向的margin不会影响页面的布局- display 可以用来设置元素显示的类型可选值:inline:将元素设置为行内元素block: 将元素设置为块元素inline-block:将元素设置为行内块元素行内块元素,即可以设置宽度和高度又不会独占一行table:将元素设置为一个表哥none:元素不在页面中显示- visibility 可以用来设置元素显示状态可选值:visible(默认值):元素在页面正常显示hidden:元素在页面中隐藏(不显示),但是依然占据页面的位置·高度塌陷和BFC高度塌陷的问题:- 在浮动布局中,父元素的高度默认是被子元素撑开的,当子元素浮动后,其会完全脱离文档流,子元素从文档流中脱离,将会无法撑起父元素的高度,导致父元素的高度丢失。- 父元素高度丢失以后,其下的元素会自动上移,导致页面的布局混乱- 高度塌陷是浮动布局中比较常见的一个问题,这个问题我们必须要进行处理BFC ( Block Formatying Context )    块级格式化环境-BFC是一个CSS中的一个隐含的属性,可以为一个元素开启BFC开启BFC该元素会变成一个独立的布局区域- 元素开启BFC后的特点:1. 开启BFC的元素不会被浮动元素所覆盖  2. 开启BFC的元素的子元素和父元素外边距不会重叠3. 开启BFC的元素可以包含浮动的子元素-可以通过一些特殊方式来开启元素的BFC:1. 设置元素的浮动(不推荐)2. 将元素设置为行内块元素(不推荐)3. 将元素的overflow设置为一个非visible的值-常用方式:为元素设置overflow: hidden 开启BFC(以使其可以包含浮动元素)· clear- 如果我们不希望某个元素因为其他元素浮动的影响而改变位置,可以通过clear属性来清除元素对当前元素所产生的影响- clear:- 作用:清除浮动元素对当前元素所产生的影响- 可选值:left:清除左侧浮动元素对当前元素的影响right:清除右侧浮动元素对当前元素的影响both:清除两侧浮动元素影响最大的那侧·高度塌陷的最终解决方案(使用after伪类).box::after{content: '';display: block;clear: both;}解决高度塌陷和外边距重叠(同时解决方案):.clearfix::before,.clearfix::after{content: '';display: table;clear: both;}

定位

定位(position)- 定位是一种更加高级的布局手段- 通过定位可以将元素摆放到页面的任意位置- 使用position属性来设置定位可选值:static:默认值,元素是静止的没有开启定位relative:开启元素的相对定位absolute:开启元素的绝对定位fixed:开启元素的固定定位sticky:开启元素的粘滞定位- 相对定位(position: relative):- 当元素的position属性值设置为relative时则开启了元素的相对定位- 相对定位的特点:1. 元素开启相对定位以后,如果不设置偏移量元素不会发生任何的变化2. 相对定位时参照于元素在文档流中的位置进行定位的3. 相对定位会提升元素的层级4. 相对定位不会使元素脱离文档流5. 相对定位不会改变元素的性质块还是块,行内还是行内- 偏移量(offset)- 当元素开启了定位以后,可以通过偏移量来设置元素的位置top:-定位元素和定位位置上边的距离bottom:- 定位元素和定位位置下边的距离- 定位元素垂直方向的位置由top和bottom两个属性来控制- 通常情况下我们只会使用其中之一- top值越大,定位元素越向下移动- bottom值越大,定位元素越向上移动left:-定位元素和定位位置的左侧的距离right:   -定位元素和定位位置的右侧的距离- 定位元素垂直方向的位置由left和right两个属性来控制- 通常情况下我们只会使用其中之一- left值越大,定位元素越向右移动- right值越大,定位元素越向左移动-绝对定位(position: absolute; )-当元素的position属性值设置为absolute时,则元素开启了元素的绝对定位- 绝对定位的特点:1. 开启了绝对定位后,如果不设置偏移量元素的位置不会发生变化2. 开启绝对定位后,元素会从文档流中脱离3. 绝对定位会改变元素的性质,行内元素变成块,块的宽度和高度被内容撑开4. 绝对定位会使元素提升一个层级5. 我们的绝对定位元素使相对于其包含块元素进行定位的 包含块元素(containing block)- 正常情况下:包含块就是离当前元素最近的祖先快元素例如:<div><span></span></div>- 绝对定位的包含块:包含块就是离它最近的开启了相对定位的祖先元素,如果所有的祖先元素都没有开启相对定位则根元素就是它的包含块- html (根元素、初始包含块)-固定定位(position: fixed; )- 将元素的position属性设置为fixed则开启了元素的固定定位- 固定定位也是一种绝对定位,所以固定定位的大部分特点都和绝对定位一样- 唯一不同的是,固定定位永远参照于浏览器的视口进行定位固定定位的元素不会随着页面的滚动条滚动- 粘滞定位(position: sticky)- 当元素的position属性设置为sticky时则开启了元素的粘滞定位- 粘滞定位和相对定位的特点基本一样,不同的是粘滞地位可以在元素到达某个位置时将其固定- 绝对定位元素的布局- 水平布局- 垂直方向布局的等式必须满足left + margin-left + border-left + padding-left + width + padding-right + border-right + margin-left  + right = 其父元素内容区的宽度- 当我们开启了绝对定位后:- 水平方向的布局等式就要添加 left 和 right 两个值,此时规则和之前一样,只是多添加了两个值。- 当发生过度约束:如果9个值中没有 auto则自动调整right 的值以使等式满足如果有auto, 则自动调整auto的值使等式满足-可设置auto的值:margin  width  left  right-因为left 和right 的值默认是auto,所以如果不知道left和right的值,则等式不满足时,会自动调整这两个值  - 垂直布局- 垂直方向布局的等式必须满足top + margin-top/bottom +padding-top/bottom + border-top/bottom + height =  包含块的高度- 元素的水平垂直居中代码:.box{margin: auto;top:0;bottom:0;left:0;right:0;}

元素的层级

对于开启了定位元素,可以通过z-index属性来指定元素的层级   :- z-index需要一个整数作为参数,值越大元素的层级越高,元素的层级越高越优先显示- 如果元素的层级相同,会优先显示靠下的元素- 祖先元素的层级再高也不会盖住后代元素

字体族

字体相关的样式:color:用来设置字体颜色font-size:用来设置字体的大小- 和font-size相关的单位:em相当于当前元素的一个font-sizerem相当于根元素的一个font-size- font-family 字体族(字体样式)可选值:serif:衬线字体sans-serif:非衬线字体monospace:等宽字体- 指定字体的类别,浏览器会自动使用该类别下的字体- font-family 可以同时指定多个字体,多个字体间使用,隔开字体生效时优先使用第一个,第一个无法使用则使用第二个,以此类推         -font-face 可以将服务器中的字体直接提供给用户去使用- 问题:1. 加载速度2. 版权问题- 用法:@font-face{font-family: 'myfont';src: url('./路径');}

图片字体

· 图片字体(iconfront)-在网页中经常需要使用一些图标,可以通过图片来引入图标但是图片的大小本身比较大,并且非常不灵活- 所以在使用图片时,我们还可以将图片直接设置为字体,然后通过font-face的形式来对字体进行引入- 这样我们可以通过使用字体的样式的形式来使用图标· fontawesome 使用步骤:1. 下载https://fontawesome.com/2. 解压3. 将css和webfonts移动到项目中4. 将all.css引入到网页中5. 使用图标字体- 直接使用类名来使用图标字体· 图标字体的其他使用方式通过伪元素来设置图标字体1. 找到要设置图标的元素通过before或after选中2. 在content中设置字体的编码3. 设置字体的样式:fab:font-family: 'Font Awesome 5 Brands'fas:font-family: 'Font Awesome 5 Brands';font-weight: 900;4. 通过实体来使用图标字体:&#( 图标的编码 ); · 阿里字体图标库( iconfront)

行高

行高(line height)- 行高指的是文字占有的实际高度- 可以通过line-height来设置行高行高可以直接指定一个大小(px  em),也可以直接为行高设置一个整数如果是一个整数的话,行高将会是字体的指定的倍数- 行高经常还用来设置文字的行间距- 行间距 = 行高 - 字体大小字体框- 字体框就是字体存在的格子,设置font-size实际上就是在设置字体框的高度- 行高会在字体框的上下平均分配通常将行高设置为和高度一样的值,使单行文字在一个元素中垂直居中

字体的简写属性

· font 可以设置字体相关的所有属性语法:font :字体大小/行高    字体族 (行高可以省略不写,如果不写会使用默认值)· font-weight 字重,字体的加粗可选值:normal:默认值,不加粗bold:加粗100-900 九个级别(没有区别)· font-style 字体的风格normal 正常的italic 斜体

文本的水平和垂直对齐

· text-align:文本的水平对齐可选值:left:左侧对齐right:右侧对齐center:居中对齐justify:两端对齐· vertical-align:文本的垂直对齐可选值:baseline:默认值,基线对齐top:顶部对齐bottom:底部对齐middle:居中对齐· 其他的文本样式- text-decoration:设置文本修饰可选值:none:什么都没有underlin:下划线line-through:删除线overline:上划线- white-space:设置网页如何处理空白可选值:normal:正常nowrap:不换行pre:保留空白

背景

· background-color(设置背景颜色)
· backgro-image(设置背景图片)- 可以同时设置背景图片和背景颜色,这样背景颜色将会将会成为背景图片的背景色- 如果背景图片小于元素,则背景图片会自动在元素中平铺,将元素铺满- 如果背景的图片大于元素,将会一个部分背景无法完全显示- 如果背景图片和元素一样大,则会直接正常显示· background-repeat(用来设置背景的重复方式)可选值:repeat :默认值,背景会沿着x轴 y轴双方向重复repeat-x:沿着x轴的方向重复repeat-y:沿着y轴的方向重复no-repeat:背景图片不重复· background-position(用来设置背景图片的位置)可选值:- 通过 top  left  right  bottom  center 几个表示方位的词来设置背景图片的位置- 使用方位词时必须同时指定两个值,如果只写一个则第二个默认就是center- 通过偏移量来设置背景图片的位置:水平方向的偏移量,垂直方向的偏移量· background-clip(设置背景的范围)可选值:border-box:默认值,背景会出现在边框的下边padding-box:背景不会出现在边框,只出现在内容区和边框content-box:背景只会出现在内容区· background-origin(背景图片的偏移量计算的原点)可选值:padding-box:默认值,background-position从内边距处开始计算content-box:背景图片的偏移量从内容区开始处计算border-box:背景图片的变量从边框处开始计算· background-size(设置背景图片的大小)   - 第一个值表示宽度- 第二个值表示高度- 如果只写一个值,则第二个值默认是auto- cover:图片的比例不变,将元素铺满- contain:图片的比例不变,将图片在元素中完整显示· background-attachment(背景图片是否跟随元素移动)可选值:scroll:默认值,背景图片会跟随元素移动fixed:背景图片会固定在页面中,不会随元素移动· background背景相关的简写属性,所有背景相关的样式都可以通过该样式来设置,并且该样式没有顺序要求,也没有哪个属性是必须写的· 注意:- background-size:必须写在background-position的后面,并且使用/隔开background-position/background-size- background-origin  background -clip两个样式,origin必须在clip的前面· 图片闪烁问题:
- 图片属于网页中的外部资源,外部资源都需要浏览器单独发送请求加载,浏览器加载外部资源时是按需加载的(用则加载,不用则不加载)
- 解决图片闪烁的问题:1. 可以将多个小图片统一保存到一个大图片中,然后通过调整backgr-position开显示相应的图片2. 这样图片会同时加载到网页中,就可以有效的避免来闪烁问题3. 这个技术在网页中的应该十分广泛,被称为CSS-Sprite,这种图我们称为雪碧图· 线性渐变- 通过渐变可以设置一些复杂的背景颜色,可以实现从一个颜色向其他颜色过渡的效果!!渐变是图片,需要通过background-image来设置- 线性渐变,颜色沿着一条直线发生变化 linear-gradient()例子:linear-gradient(red,yellow)红色在开头,黄色在结尾,中间是过渡区域- 线性渐变的开头,我们可以指定一个渐变的方向to left: 向左to right:向右to bottom:向下to top:向上xxxdeg (deg表示度数)turn (表示圈)- 渐变可以同时指定多个颜色,多个颜色默认情况下平均分布repeating-linear-gradient()可以平铺的线性渐变· 径向渐变radial-gradient()径向渐变(放射性的效果)- 默认情况下,径向渐变圆心的形状根据元素的形状来计算的正方形-->圆形长方形-->椭圆形-我们也可以手动指定径向渐变的大小,也可以指定渐变的位置- 语法:radial-gradient(大小  at  位置,颜色  位置,颜色  位置...)- 大小:circle:圆形ellipse:椭圆closet-side:近边closet-corner:近角farthest-side:远边farthest-corner:远角- 位置:top  right  left  center  bottom

雪碧图

- 雪碧图的使用步骤:1. 先确定要使用的图标2. 测量图标的大小3. 根据测量结果创建一个元素4. 将雪碧图设置为元素的背景图片5. 设置一个偏移量以显示正常的图片- 雪碧图的特点:一次性将多个图片加载进页面,降低请求的次数,加快访问速度,提升用户体验<br></br>

表格的简介

- 在我们现实社会中,我们经常需要使用表格表示一些格式化数据(课程表、人名单、成绩单...)- 表格的创建- 同样在网页中我们也需要使用表格,我们通过table标签来创建一个表格- 在table中使用tr表示表格中的一行,有几个tr就有几行- 在tr中使用td表示一个单元格,有几个td就有几个单元格- colspan 横向的合并单元格- rowspan 纵向的合并单元格- 长表格可以将一个表格分成三个部分:头部:thead主体:tbody底部:tfoot- 表格的样式border-spacing:指定边框之间的距离border-collapse:collapse;设置边框的合并- 如果表格中没有使用tbody而是直接使用tr,那么浏览器会自动创建一个tbody,并且将全部tr都放到tbody- tr不是table的子元素- 默认情况下元素在td中是垂直居中的,可以通过vertical-align来调整- 将元素设置为单元格display: table-cell;vertical-align: middle;<br></br>

表单

- 表单在我们的现实生活中用于提交数据
- 在网页中也可以使用表单,网页中的表单用于将本地的数据提交给远程的服务器- 使用form标签来创建一个表单
- form的属性:action:指定表单要提交的服务器的地址- 表单项- 文本框(<input type="text" name="username">):注意:数据要提交到服务器中,必须要为元素指定一个name属性值-   密码框(<input type="passward" name="userword">)- 单选按钮(<input type="radio" name="名字">):像这种选择器,必须要指定一个value属性,value属性最终会作为用户的填写的值传递给服务器-    多选框(<input type="checkbox" name="名字">)-   下拉列表(<select name="名"><option value="值1">选项一</option><option selected(默认选中) value="值2">选项二</option></select>)- 提交按钮(<input type="submit" value="值">)-    重置按钮(<input type="reset">)-  普通按钮(<input type="button" value="值">)- 按钮中的属性- autocomplete="on/off" 开启/关闭自动补全- readonly 将表单项设置为只读,数据会提交- disabled 将表单项设置为禁用,数据不会提交- autoforce 设置表单项自动获取焦点

默认样式- 通常情况下,浏览器都会为元素设置一些默认样式- 默认样式的存在会影响到页面的布局通常情况下编写网页时必须要去除浏览器到默认样式(pc端端页面)-重置样式表,专门用来对浏览器到样式进行重置的reset.css 直接去除来浏览器到默认样式normalize.css 对默认样式进行了统一

CSS选择器+盒子模型+定位( 基础笔记 )相关推荐

  1. CSS样式中选择器+盒子模型+定位+浮动

    CSS样式中选择器+盒子模型+定位+浮动 一.选择器 选择器,选择你所需要修饰的HTML元素 1.通配符选择器 <!DOCTYPE html> <html><head&g ...

  2. 超详细的css知识树状图~CSS选择器盒子模型、浮动、定位和装饰

    前言 学习任何新知识,最重要的永远都是搭建属于自己的知识框架,随后学习的细碎知识点往框架里面填入,最后形成一棵属于自己的知识大树.本系列的博客专注更新总结好的思维导图,希望可以帮助大家快速理清知识结构 ...

  3. 个人笔记-css实现盒子模型水平居中和垂直居中

    CSS实现盒子模型水平居中的方法 1.margin+width 适用于盒子的宽度是已知的 <div class="parent"><div class=" ...

  4. css模型安装,【CSS】CSS-框模型+定位+实训练习

    <[CSS]CSS-框模型+定位+实训练习>由会员分享,可在线阅读,更多相关<[CSS]CSS-框模型+定位+实训练习(9页珍藏版)>请在人人文库网上搜索. 1.第二阶段-We ...

  5. CSS--背景样式---伪类选择器---高级选择器---盒子模型---浮动

    文章目录 背景样式 背景颜色 背景图片 图片重复方式 图片位置 图片附着 简写属性 伪类选择器 高级选择器 后代选择器 直接后代选择器 并列选择器 相邻兄弟选择器 盒子模型 边框 内边距 外边距 外边 ...

  6. CSS3新增-属性(长度颜色背景)选择器-盒子模型

    属性(长度颜色背景)选择器-盒子模型 1 CSS3 基本语法 1.1 CSS3 浏览器私有前缀 Chorme: -webkit- Safari: -webkit- IE; -ms- Firefox: ...

  7. css中 盒模型的属性包括(),css的盒子模型属性有哪些?css盒子模型相关属性的介绍...

    本篇文章给大家带来的内容是关于css的盒子模型属性有哪些?css盒子模型相关属性的介绍,有一定的参考价值,有需要的朋友可以参考一下,希望对你有所帮助. 1.盒子模型图 2.一个简单的盒子模型 box. ...

  8. php盒子模型,HTML与CSS的盒子模型

    这次给大家带来HTML与CSS的盒子模型,使用HTML与CSS的盒子模型的注意事项有哪些,下面就是实战案例,一起来看一下. 一.边框 (上) 1.什么边框? 边框就是环绕在标签宽度和高度周围的线条 2 ...

  9. html盒子模型页面居中,【静态页面架构】CSS之盒子模型

    CSS架构 盒子模型: 以内容区(显示文本和图像) 内边距(内容区至边距的距离) 边距(内容区的边界) 外边距(元素的边框之间的距离) 1.边距: border属性: 简写属性用来设置边距的上(top ...

最新文章

  1. 小白学习python好还是java好_小白应该学Python还是Java?
  2. Spring Boot: Tuning your Undertow application for throughput--转
  3. linux常用系统命令
  4. 使用Jest进行单元测试
  5. 一款超强的手机屏幕投影工具
  6. jstl表达式替换某些字符
  7. 三星计算机用户的密码忘了,如果三星计算机忘记了开机密码怎么办
  8. python编程跳一跳_使用Python实现跳一跳自动跳跃功能
  9. 已设置的指纹解锁怎样解除_指纹锁哪个牌子更好用?
  10. 10. Regular Expression Matching[H]正则表达式匹配
  11. cad画流程图的插件_如何用cad画交互流程图
  12. UIScrollView---iOS-Apple苹果官方文档翻译
  13. 明尼苏达大学研究者为bug事件致歉
  14. windows和linux共用蓝牙鼠标,双系统共用蓝牙键鼠(win10+macOS)
  15. Unity3d模型,加入Animator后,播放动画,物体回归原位处理
  16. 智商黑洞(门萨Mensa测试)4
  17. Android自定义不需要焦点的TextView以实现跑马灯效果
  18. 软件测试实用教程答案,软件测试实用教程
  19. ADAS/AD 系统验证方法及策略(dSPACE解决方案)
  20. html背景怎么改成护眼模式,Win10窗口的白色背景颜色怎么设置成护眼色?

热门文章

  1. 计算机左边桌面选项没了,我的电脑里的左侧工具栏不见了怎么办?
  2. 主人给狗狗扔零食,小狗无奈吐槽,教你制作搞笑配音短视频
  3. 2018年作息及读书计划
  4. Qt Design Studio的3D编辑器
  5. 【超哥要求】SQL基础语法__邓慧斐
  6. 一个玩游戏的失足青年,转行做编程到教育的挣扎过程(2/4)
  7. Python Plugin loader tut for ida pro 7.0
  8. 求超大文件上传方案( js )
  9. 【Python自然语言处理】使用逻辑回归(logistic)对电影评论情感分析实战(超详细 附源码)
  10. 网络安全之社会工程学