首页 > 编程语言 >CSS基础(基于黑马程序员视频的学习笔记)

CSS基础(基于黑马程序员视频的学习笔记)

时间:2022-09-28 00:55:17浏览次数:61  
标签:行内 标签 元素 选择器 程序员 黑马 CSS 属性

一、CSS选择器

1、标签选择器

  • 选中所有的该标签

标签名 {
CSS属性名:属性值;
}

2、类选择器

.类名 {
CSS属性名:属性值;
}
  • 所有标签都有class属性,class属性的属性值称为类名

  • 类名可以由数字、字母、下划线、中划线组成,但不能以数字或中划线开头

  • 一个标签可以有多个类名,类名之间以空格隔开

  • 类名可以重复,一个类选择器可以选中多个标签

3、id选择器

#id {
CSS属性名:属性值;
}
  • 所有标签都有id属性

  • id属性在一个页面中不可重复

  • 一个标签只能有一个id

  • 一个id选择器只能选中一个标签

4、通配符选择器

* {
CSS属性名:属性值;
}

选中所有标签

如果给同一个标签设置了相同的属性,此时样式会重叠,写在下面的会生效

p {
color:red;
color:blue;
}
/* p标签会显示为蓝色 */

5、后代选择器

选择器1 选择器2 {CSS}(有空格)

后代包括:孩子,孙子,重孙。。。

6、子代选择器

只包括孩子一代

选择器1>选择器2 {CSS}

7、并集选择器

选择器1,选择器2{CSS}

并集选择器中的每组选择器可以是基础选择器或者复合选择器

8、交集选择器

选择器1选择器2{CSS}(无空格)

如:p标签且class="box"

p.box{CSS}

9、hover伪类选择器

选择器:hover{CSS}

伪类选择器选中的元素的某种状态,任何标签都可以添加伪类

 

二、字体和文本样式

1、字体样式

默认字号是16

font-size:字体大小

font-weight:字体粗细

font-style:字体样式

font-family:字体

font-family:微软雅黑,黑体,sans-serif;
/* 表示如果用户电脑没有安装微软雅黑,则按黑体显示,若没有安装黑体,则按任意一种非衬线字体显示 */

font复合属性:font:style weight size/line-through family;

只能省略前两个属性,相当于设置了默认值

 

2、文本样式

缩进:

text-indent:xxpx/xem;

em:一个字的大小

 

水平对齐:

text-align:left/center/right;

文本spanainputimg水平居中,text-align需要给以上标签的父级标签

标签居中总结:margin:0 auto

 

文本修饰:

text-decoration:underline/line-through/overline/none;

underline:下划线,line-through:删除线,overline:上划线,none:无装饰线

 

行高:

line-height:xxpx/font-size的倍数; 注意:行高=上间距+文本高度+下间距

使用font:style weight size/line-through family;时,注意覆盖问题

 

三、背景

1、背景颜色 | 图

background-color:可以设置颜色/十六进制/rgb(a)

background-image:url(图片路径)

 

2、背景平铺

background-repeat属性

repeat:默认,水平和垂直方向都平铺

no-repeat:不平铺

repeat-x:沿x轴平铺

repeat-y:沿y轴平铺

 

3、背景位置

background-position:水平方向位置 垂直方向位置;

水平:left center right

垂直:top center bottom

或者均采用px移动,(以父容器左上角为原点)正数向右向下移动,负数向左向上移动

 

4、复合属性(不要求顺序)

推荐写法:background:color image repeat position

 

四、元素显示模式

1、块级元素

div、p、h系列、ul、li、dl、dt、dd、form、header、nav、footer...

可以设置宽高,独占一行

 

2、行内元素

a、span、b、u、i、s、strong、ins、em、del...

不可以设置宽高,一行可以显示多个

 

3、行内块元素

input、textarea、button、select...

特殊情况:img标签有行内块特点,但是Chrome调试工具中是inline

一行可以显示多个,可以设置宽高

 

4、元素显示模式转换

display:block:转换成块级元素

display:inline-block:转成行内块元素

display:inline:转成行内元素

 

TIPS:标签嵌套注意点

1、块级元素一般作为大容器,可以嵌套:文本、块级元素、行内元素、行内块元素等等......

但是p标签中不要嵌套div、p、h等块元素

2、a标签内部可以嵌套任意元素,但不能嵌套a标签

 

五、CSS特性

1、继承性

子元素默认继承有父元素样式的特点

常见的可继承属性:color、font-style、font-weight、font-size、font-family、text-align、text-indent、line-height...

(控制文字的属性都能继承,反之)

继承失败的情况:a标签的color、h系列标签的font-size

 

2、层叠性

注意:当样式冲突时,当选择器优先级相同时,才能通过层叠性判断结果

 

3、优先级

继承 < 通配符选择器 < 标签选择器 < 类选择器 < id选择器 < 行内样式 < !important

!important写在属性值的后面,分号的前面,且不能提升继承的优先级

如:

div{
color:green !important;
}

如果优先级相同,则按行内、id、类、标签的顺序比较选择器个数,个数多的优先级高

 

六、盒子模型

CSS规定每个盒子由内容区域content内边距区域padding边框区域border外边距区域margin构成,这就是盒子模型

1、内容content

width、height默认设置盒子内容大小

 

2、边框border

border:10px solid red (不分先后顺序)

分别表示边框方向,边框粗细,边框线类型,边框颜色 solid实线、dashed虚线、dotted点线

也可以使用单独属性:border-方位词/width/style/color,但更常用符合属性

 

3、内边距padding

padding属性可以当作符合属性使用,最多可以取四个值,表示上右下左;两个值表示上下 左右;三个值表示上 左右 下

盒子模型最终大小 = width/heigth + 2*border + 2*padding

给盒子设置属性box-sizing:border-box;,浏览器会自动计算多余大小,自动在内容中减去,无需计算border和padding给盒子大小造成的影响

 

4、外边距margin

设置方式同padding

浏览器会给部分标签默认设置margin和padding,但一般在项目开始时需要清楚默认样式,所以需:

* {
margin:0;
padding:0;
}

 

外边距问题

折叠问题:

垂直布局的块级元素,上下的margin会合并(取最大值)

解决方案:只给设置一个元素margin

塌陷问题:

互相嵌套的块级元素,子元素的margin-top会作用在父元素上,导致父元素一起往下移动

解决方案:给父级元素设置border-toppadding-top、给父级元素设置overflow:hiden、转换成行内块元素、设置浮动

行内元素的垂直内外边距:

无法通过paddingmargin改变行内标签的位置

解决方法:加行高

 

七、浮动

1、结构伪类

E:first-child{} :匹配父元素中第一个子元素,并且是E元素

E:last-child{} :匹配父元素中最后一个子元素,并且是E元素

E:nth-child(n){} :匹配父元素中第n个子元素,并且是E元素

E:nth-last-child(n){} :匹配父元素中倒数第n个子元素,并且是E元素

注:n可以为0、1、2、3...或公式,如even(基数)、odd(偶数)、-n+5(找到前五个)、n+5(从第五个开始往后)

 

2、伪元素

一般页面中的非主题元素可以使用伪元素,是由CSS(非HTML) 模拟出的标签效果

::before:在父元素内容的最前面添加一个伪元素

::after:在父元素内容的最后面添加一个伪元素

伪元素必须设置content属性才能生效,且默认是行内元素

/* 示例 */
div::before{}
div::after{}

 

常见标准流规则:

块级元素:从上往下,垂直布局,独占一行

行内(块)元素:从左往右,水平布局,空间不够自动拆行

 

3、浮动

浏览器解析行内(块)元素时,如果代码有换行,则会有间距

浮动早期用于图文环绕,现在则用于网页布局

{
float:left/right;

}

特点:

  • 浮动元素会脱离标准流,在标准流中不占据位置

  • 浮动元素会比标准流高半个级别,可以覆盖标准流中的元素

  • 下一个浮动元素会在上一个浮动元素的左右浮动

  • 浮动后的标签具有行内块特点

  • 添加浮动后margin对水平效果的调整不生效,因为浮动更高级

 

4、清除浮动

如果子元素浮动,则此时不能撑开标准流的块级父元素

方法:

  • 父元素添加高度

  • 额外标签法:在父元素内容的最后添加一个块级元素,并设置属性clear:both(但会让页面html结构更复杂)

  • 单伪元素清除

.clearfix::after{
content:'';
display:block;
clear:both;
/* 以下是补充代码,在网页中看不到伪元素;在高版本浏览器无区别,主要是为了适配低版浏览器 */
height:0;
visibility:hidden;
}
  • 双伪元素清除

/* before作用:解决外边距塌陷 */
.clearfix::before,
.clearfix::after{
content:'';
dispaly:table;
}
.clearfix:after{
clear:both;
}
  • 设置overflow:hidden

{
overflow:hidden;
}

 

八、定位

1、使用定位

设置定位方式:

  • position:属性名

  • static:静态定位(没用,不会改变位置)

  • relative:相对定位

  • absolute:绝对定位

  • fixed:固定定位

  • lr都有,以l为准,tb都有,以t为准

设置偏移值:

  • left、right、top、bottom

 

2、相对定位

position:relative

  • 占有原来的位置(不脱标)

  • 仍然具有原有标签的显示特点

  • 改变位置参照原位置

应用场景:

  • 配合绝对定位(子绝父相)

  • 用于小范围的移动

 

3、绝对定位

position:absolute

  • 不占有原来的位置(脱标)

  • 改变标签的显示特点(变成行内块特征)

  • 先找已定位的父级(大多采用相对,就近原则),若有就以这个父级为参照物进行定位;若无已定位的父级,以浏览器窗口为参照物进行定位

应用场景:

  • 子绝父相

 

3、居中

绝对定位的盒子无法使用margin:0 auto

  • 定位居中

/* 水平居中 */
position:absolute;
left:50%;
margin-left:-???px; /*盒子宽度一半*/

/* 垂直居中 */
position:absolute;
top:50%;
margin-top:-???px; /*盒子高度一半*/
  • 位移居中

/* 位移自己宽高的一半 */
transform:translate(-50%,-50%);

 

4、固定定位

position:fixed

  • 不占据原来位置(脱标)

  • 改变位置参考浏览器窗口

  • 具有行内块特点

 

5、显示层级

  • 默认情况下,定位的盒子后写的居上

  • z-index:整数,取值越大,显示顺序越靠上,默认取值0

  • z-index必须配合定位才生效

 

6、装饰

① vertical-align

  • baseline:默认,基线对齐

  • top:顶部对齐

  • middle:中间对齐

  • bottom:底部对齐

浏览器遇到行内和行内块元素当作文字处理,默认按照基线对齐,可以通过vertical-align:middle居中,也可以display:block;处理

.father{
width:600px;
height:600px;
line-height:600px;
/* 水平居中 */
text-align:center;
}

img{
/* 垂直居中 */
vertical-align:middle;
}

 

② 光标类型:

cursor

  • default:默认值,通常是箭头

  • pointer:手,提示用户可以点击

  • text:工字型,提示用户可以选择文字

  • move:十字光标,提示用户可以移动

 

③ 边框圆角

border-radius:数字/百分比

  • 最大取值50%,即正圆

  • 从左上角开始赋值,然后顺时针,没有赋值看对角

 

常见应用:

  • 正圆

    • 盒子必须是正方形

    • 设置border-radius:50%

  • 胶囊按钮

    • 盒子必须是长方形

    • 设置border-radius:盒子高度一半

 

④ 溢出部分显示效果

overflow

  • visible:默认值,溢出部分可见

  • hidden:溢出部分隐藏

  • scroll:无论是否溢出,都显示滚动条

  • 根据是否溢出,自动显示或隐藏滚动条

 

⑤ 元素本身隐藏

  • visibility:hidden:占位隐藏

  • dispaly:none(常用):不占位隐藏

 

⑥ 元素整体透明度(拓展)

opacity:0~1之间的数字

opacity会让元素整体透明,包括其中的文字、图片

 

九、项目样式补充

1、精灵图

项目中将多张小图片合成一张大图片,成为精灵图

优点:减少服务器发送次数,减轻服务器压力,提高页面加载速度

  • 不能用img标签引入精灵图,会全部显示

  • 精灵图的标签使用行内标签:spanbi...

/* 设置背景图片和位置 */
background-image:url();
background-position:水平位置 垂直位置;

设置背景图片大小background-size

  • ??px

  • 百分比:相当于当前盒子自身的宽高百分比

  • contain:包含,等比缩放,直到不会超出盒子的最大

  • cover:覆盖,等比缩放,直到刚好填满整个盒子没有空白

background连写:background:color image repeat position/size;

 

2、盒子阴影

box-shadow

  • h-shadow:必须,水平偏移量,允许负值

  • v-shadow:必须,垂直偏移量,允许负值

  • blur:可选,模糊度

  • spread:可选,阴影扩大

  • color:可选,阴影颜色

  • inset:可选,将阴影改为内部阴影

  • 值都是px

 

3、过渡

transition

  • 过渡的属性

    • all:所有能过渡的属性都过渡

    • 具体属性名:width:只有width过渡

  • 过渡的时长:?s

  • 默认状态和hover状态样式不同,才能有过渡效果

  • transition属性给需要过渡的元素本身加

  • transition给默认状态设置,鼠标移入移出都有效果

  • transitionhover状态设置,移出没有效果

/* 过渡配合hover使用,谁变化给谁加过度属性 */
.box{
width:200px;

transition:width 1s background-color 2s;
/* 若变化的属性多,直接写all
transition:all 2s;
*/
}

.box:hover{
width:600px;

}

 

4、SEO

SEO(Search Engine Optimization):搜索引擎优化,让网站在搜索引擎排名靠前

提升SEO常见方法:

  • 竞价

  • 将网页制作成html后缀

  • 标签语义化(在合适的地方使用合适的标签)

  • ......

SEO三大标签:

  • title:网页标题标签

  • description:网页描述标签

  • keywords:网页关键字标签

 

5、favicon

显示在标签页左侧的小图标,习惯使用ico格式、

ico图标设置:

<link rel="shortcut icon" href="favicon.ico" type="image/x-icon">

 

6、项目结构搭建

  • 新建项目文件夹 xtx-pc-client,在VScode中打开

    • 在实际开发中,项目文件夹不建议使用中文

    • 所有项目相关文件都保存在xtx-pc-client目录中

  • 复制favicon.icoxtx-pc-client目录

    • 一般习惯将ico图标放在项目根目录

  • 复制 imagesuploads目录到xtx-pc-client目录中

    • images :存放网站固定使用的图片素材,如: logo、样式修饰图片...等

    • uploads:存放网站非固定使用的图片素材,如:商品图片、宣传图...等

  • 新建index.html在根目录

  • 新建 CSS文件夹保存网站的样式,并新建以下CSS文件:

    • base.css:基础公共样式

    • common.css:该网站中多个网页相同模块的重复样式,如:头部、底部

    • index.css:首页样式

标签:行内,标签,元素,选择器,程序员,黑马,CSS,属性
From: https://www.cnblogs.com/ruchu045/p/16736573.html

相关文章

  • 九月第二篇关于《程序员修炼之道:从小工到专家》的阅读笔记
    《程序员修炼之道:从小工到专家》阅读笔记这本书是自从进入软件工程系以来所阅读的第二本书,本篇是九月的第二篇阅读笔记,希望在这里记录一些我的感悟。书中中间几个章节提......
  • css语言
    css:样式表、级联样式表、层叠样式表css写在style标签里面,放在head标签中;大括号中写键值对语法color:文字颜色Font-family:字体Font-size:字号text-indent:首行缩进单位......
  • 前端三件套 HTML+CSS+JS基础知识内容笔记
    HTML基础目录HTML基础HTML5标签doctype标签html标签head标签meta标签title标签body标签文本和超链接标签标题标签段落标签换行标签水平标签强调标签图片标签与超链接标签......
  • CSS3 实现 网页顶部进度条
    有朋友们问网页顶部进度条 如何应用,现在github大部分国外网站都在用,这个效果可以使用现成的一些插件比如 ​​这个​​​,​​这个​​​,还有​​这个​​。比如youtobe......
  • 一首诗 送给每天加班的程序员们
    一首打油诗献丑「程序员-打油诗 」文/小北哥哥天尚好,云已散, 天天加班没人恋;挤公交, 抗地铁, 练就一副好身段; 调了休, 上了岸, 人生旅途又一站; 图心宽, 求康健, 是是......
  • 程序员 挣钱比健康重要
    今天说点关于健康的 这些天一直没更新,前些天去了一趟医院,平时身体很好,基本和医院医生无缘,这次我心灵的窗户出问题了!我生“病”了迎风流泪、不迎风也流泪、眼睛酸疼浑......
  • 程序员 你努力的方向对吗?
    今天来思考下为何努力 由于现在网络普及很快,自然编程这个事在普通人群也就耳熟能详了,甚至大部分人已经知道【程序猿】是个什么性质的群体,早些年还相当陌生。然后,然后,越来......
  • 程序员修炼之道——从小工到专家读后感
    一:我的源码让猫吃了这一节教会我要有责任心要负责。一、如果承诺了某件事,就要信守承诺完成它,尽管事情可能不尽人意使你不能完成它,但你起码是尽你所能去做了,而不是因为不......
  • 《程序员修炼之道:从小工到大家》读后感(二)
    我来继续分享对这本书的阅读感受啦!我这次继续接触了这本书,不得不说,这本书让不爱看书的我有点儿放不下了,它用生动形象的语言,让我每次翻开这本书时,都有种休闲娱乐的错觉,可能......
  • [css]一个块格式化上下文(BFC)阻止外边距重叠的示例
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>Document</title><style>*{margin:0;paddin......