web前端:css基本操作

1. 概述

css是英文Cascading Style Sheets的缩写,称为层叠样式表,用于对页面进行美化。

存在方式有三种:元素内联、页面嵌入和外部引入,比较三种方式的优缺点。

语法:style = ‘key1:value1;key2:value2;‘

  • 行内式:

在标签中使用 style=‘xx:xxx;‘单独加在某个标签上,style增加其他属性需要以分号分隔;


1

2

<div style="height: 100px;width:100px">我是div

</div>

  • 嵌入式:

在页面中嵌入 < style type="text/css"> </style >块


1

2

3

4

5

6

7

8

9

10

11

<head>

<meta charset="UTF-8">

<title>Title</title>

<style>

div{

background-color:darkgrey;

height: 100px;

width:100px;

}

</style>

</head>

  • 链接式:

将.css文件引入到HTML文件中,创建一个.css文件,将css文件放入link标签中


1

2

3

4

5

<head>

<meta charset="UTF-8">

<title>Title</title>

<link href="mystyle.css" rel="stylesheet" type="text/css"/>

</head>

  • 导入式:

将一个独立的.css文件引入HTML文件中,导入式使用CSS规则引入外部CSS文件,<style>标记也是写在<head>标记中


1

2

3

4

5

6

7

<head>

<meta charset="UTF-8">

<title>Title</title>

<style type="text/css">

@import"mystyle.css"#此处要注意.css文件的路径

</style>

</head>

注意:import 会先解析页面所有信息,先不会渲染页面,等待所有信息加载后再渲染页面,如果加载慢会出现无渲染页面,导致用户体验不好,推荐使用嵌入式和链接式

2. CSS选择器

2.1 基础选择器

2.1.1 通用元素选择器

通用元素选择器,匹配任何元素


1

2

3

*{

color: darkgrey;

}

2.1.2 标签选择器

匹配所有使用XX标签的元素;

例如,需要选择所有标签为div的元素设置样式


1

2

3

4

div{

color: grey;

background-color: antiquewhite;

}

2.1.3 class选择器

.info 或E.info :class属性选择器,匹配所有class属性中包含info的元素,class属性可以重复,即多个class属性相同的元素;


1

2

3

4

5

6

7

8

9

.cs1{

color: grey;

background-color: antiquewhite;

}

<div class="cs1">我是div1标签</div>

<div class="cs1">我是div2标签</div>

<p class="cs1">我是p标签</p>

<!-- 以上三个标签都会变成.cs1的样式 -->

2.1.4 id选择器

#info或E#info :id属性选择器,匹配所有id属性等于info的元素


1

2

3

4

5

6

7

8

#cs1{

color: grey;

background-color: antiquewhite;

}

<div id="cs1">我是div1标签</div>

<div class="cs1">我是div2标签</div>

<!-- 以上标签,只有id=cs1的标签会变成#cs1的样式-->

2.2 组合选择器

2.2.1 多元素选择器

E,F:多元素选择器,同时匹配所有E标签元素或F标签元素,E和F之间用逗号分隔


1

2

3

4

5

6

7

8

9

div,p{

color: grey;

background-color: antiquewhite;

}

<div id="cs1">我是div1标签</div>

<p class="cs1">我是p标签</p>

<span>我是span</span>

<!-- 以上标签,除span标签,即div和p标签都会变成设置的样式-->

2.2.2 后代元素选择器

E F:后代元素选择器,匹配所有属于E标签元素后代的F标签元素,即所有类似形式的所有后代,子子孙孙,E和F之间用空格分隔;


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

div p{

color: grey;

background-color: antiquewhite;

}

<div id="cs1">

  <p class="cs1">我是p1标签</p>

  <div class="cs3">

    <p class="cs1">我是p2标签</p>

    <div class="cs2">

      <p id="cs1">我是p3标签</p>

    </div>

  </div>

</div>

<!-- 以上标签,p1、p2、p3均会变成设置的样式 -->

<!-- 扩展:可以结合基础选择器使用,例如div #cs1,div .cs1等 -->

2.2.3 子元素选择器

E > F :子元素选择器,匹配所有E元素的子元素F,只匹配到子元素,子元素的子元素匹配不到;


1

2

3

4

5

6

7

8

9

10

11

12

13

<style>

#outer>.c1{

color: aqua;

}

</style>

<div id="outer">

    <p class="c1">p1.....</p>

    <div class="c2">

        <p class="c1">p2....</p>

    </div>

</div>

<!-- 以上标签,p1会变成设置的样式,p2不会变,即儿子辈的会变,儿子辈的后代不会变-->

2.2.4 毗邻元素选择器

E + F:毗邻元素选择器,匹配所有紧随E元素之后的同级元素F ,即只匹配挨着的下一个F元素,如不相邻也不起作用;


1

2

3

4

5

6

7

8

9

10

11

12

<style>

#outer+.c1{

color: aqua;

}

</style>

<p class="c1">p1....</p>

<div id="outer">

</div>

<p class="c1">p2.....</p>

<div class="c1">div1...</div>

<!-- 以上标签,p1不会变更样式,p2为挨着的下一个class=c1的元素,所以p2会变更样式,div1的class属性也满足但并未挨着id=outer的元素,故不起作用 -->

2.3 属性选择器

根据属性进行筛选匹配,只有第一个input标签匹配上对应的样式


1

2

3

4

5

6

7

8

9

10

11

12

<head>

    <meta charset="UTF-8">

    <title>Title</title>

    <style>

        input[name="James"]{width: 20px;height: 20px;}

    </style>

</head>

<body>

    <input type="text" name="James">

    <input type="text">

    <input type="password">

</body>

3. 常用属性

3.1 颜色属性

color:

①英文单词形式,例如:red,yellow

②编码形式,例如:#cc3399,如双重可简写#c39

③基调颜色透明度设置,例如:rgb(255,255,255,0.5),red、green、blue三色透明度设置,最后一个值设置透明度

3.2 字体属性

font-size: 20px/50%/larger 设置字体大小;

font-family:‘Lucida Bright‘ 文本的字体系列;

font-weight: lighter/bold/border/ 字体的粗细;

font-style:normal/oblique/italic 文本的字体样式;

3.3 背景属性

background-color: 背景底色;

background-image: 背景图片;

background-repeat:平铺方式,no-repeat 不平铺,repeat 平铺满;

background-size: 图片大小设置,auto;

background-position:center 上下左右居中;left center左侧上下居中;top,bottom,right类似;

3.4 文本属性

text-align:center 文本居中

line-height:xxpx;行高 ,针对文本处理

width:xxpx;宽 %50

height:xxpx;高 %50

text-indent:xxpx 首行缩进,基于父元素

letter-spacing:xxpx;字母与字母之间距离

word-spacing:xxpx ;单词之间距离

direction:rt1

text-transform:capitalize;将单词首字母大写

min-height:设置默认最小高度

height:auto!important 以此样式为准

vertical-align:xxpx;垂直居中

opacity:0.3 透明度

3.5 CSS样式边框

border-style:solid;边框样式

border-color:red;边框颜色

border-width:1px;边框宽度

border-radius:20%;边框变成圆角


border


在一个声明中设置所有的边框属性。


border-bottom


在一个声明中设置所有的下边框属性。


border-bottom-color


设置下边框的颜色。


border-bottom-style


设置下边框的样式。


border-bottom-width


设置下边框的宽度。


border-color


设置四条边框的颜色。


border-left


在一个声明中设置所有的左边框属性。


border-left-color


设置左边框的颜色。


border-left-style


设置左边框的样式。


border-left-width


设置左边框的宽度。


border-right


在一个声明中设置所有的右边框属性。


border-right-color


设置右边框的颜色。


border-right-style


设置右边框的样式。


border-right-width


设置右边框的宽度。


border-style


设置四条边框的样式。


border-top


在一个声明中设置所有的上边框属性。


border-top-color


设置上边框的颜色。


border-top-style


设置上边框的样式。


border-top-width


设置上边框的宽度。


border-width


设置四条边框的宽度。


outline


在一个声明中设置所有的轮廓属性。


outline-color


设置轮廓的颜色。


outline-style


设置轮廓的样式。


outline-width


设置轮廓的宽度。


border-bottom-left-radius


定义边框左下角的形状。


border-bottom-right-radius


定义边框右下角的形状。


border-image


简写属性,设置所有 border-image-* 属性。


border-image-outset


规定边框图像区域超出边框的量。


border-image-repeat


图像边框是否应平铺(repeated)、铺满(rounded)或拉伸(stretched)。


border-image-slice


规定图像边框的向内偏移。


border-image-source


规定用作边框的图片。


border-image-width


规定图片边框的宽度。


border-radius


简写属性,设置所有四个 border-*-radius属性。


border-top-left-radius


定义边框左上角的形状。


border-top-right-radius


定义边框右下角的形状。


box-decoration-break

 

box-shadow


向方框添加一个或多个阴影。

简写方式:


1

border: solid 1px red

3.6 CSS样式浮动

正常文档流:将元素(标签)在进行排版布局时按照从上到下、从左到右的顺序分布排版的流;

脱离文档流:将元素从文档流中取出,进行覆盖,其他元素会按文档流中不存在该元素重新布局;

float 浮动标签属性(非完全脱离):

假如某个div元素A是浮动的,如果A元素上一个元素也是浮动的,那么A元素会跟随在上一个元素的后边(如果一行放不下这两个元素,那么A元素会被挤到下一行);如果A元素上一个元素是标准流中的元素,那么A的相对垂直位置不会改变,也就是说A的顶部总是和上一个元素的底部对齐。

注意:当初float被设计的时候就是用来完成文本环绕的效果,所以文本不会被挡住,这是float的特性,即float是一种不彻底的脱离文档流方式。

floatleftrightboth

清除浮动: clear : none | left | right | both

none : 默认值。允许两边都可以有浮动对象

left : 不允许左边有浮动对象

right : 不允许右边有浮动对象

both : 不允许有浮动对象


1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

33

34

35

36

37

<style>

    #div4{

        border:solid 1px lavender;

        background-color: rebeccapurple;

        height: 100px;

    }

    #div1{

        background-color: darkolivegreen;

        height: 100px;

        width: 980px;

        margin: auto;

    }

    #div2{

        border-left: solid 1px lavender;

        height: 100px;

        width: 100px;

        background-color: darkgray;

        float: left;

    }

    #div3{

        border-left: solid 1px lavender;

        height: 100px;

        width: 100px;

        background-color: darkgray;

        float: left;

    }

    #clear{

        clear:both;

    }

</style>

<div id="div4">

    <div id="div1">

        <div id="div2">div2</div>

        <div id="div3">div3</div>

    </div>

    <div id="clear"></div>

</div>

注:div2和div3使用float浮动起来,如想将div4的样式显示出来,需增加一个clear标签将架子撑起来,清除浮动

清除浮动第二种方法,overflow:hidden 将溢出的信息隐藏

overflow:auto;不光隐藏并出现滚动条

3.7 CSS样式display

块级标签和行内标签相互转换


1

2

3

4

<body>

    <div style="display: inline">块级</div>

    <span style="display: block">行内</span>

</body>

注:display:inline 转换为行内标签;display:block转换为块级标签;另还有display:none不显示

行内标签:无法设置高度,宽度,padding margin
块级标签:设置高度,宽度,padding margin


1

2

3

4

<body>

    <span style="display: inline-block;height: 50px;width: 70px">行内</span>

    <div style="display: inline">块级</div>

</body>

注:display:inline-block 既有inline的属性(默认自己有多少占多少)又有block的属性(可以设置高度、宽度、padding、margin)

3.8 CSS样式边距

外边距margin


1

2

3

4

5

6

<body>

    <div style="border: 2px solid red;height: 70px;">

        <div style="background-color: green;height: 50px;

        margin-top: 25px;"></div>

    </div>

</body>

内边距padding


1

2

3

4

5

6

<body>

    <div style="border: 2px solid red;height: 70px;">

        <div style="background-color: green;height: 50px;

        padding-top: 25px;"></div>

    </div>

</body>

时间: 2024-08-28 15:33:45

web前端:css基本操作的相关文章

web前端css技巧整理

"熟能生巧"这一词大家并不陌生吧,在学习web前端的时候,我们也需要做到这一点才能提高我们的工作效率等等.今天在网上发现了一篇css基础教程(http://www.maiziedu.com/course/web/421-5342/)文章,我觉得非常的有用,于是就分享给大家,这些技巧能让你更加专业. 使用:not()去除导航上不需要的边框 为body添加行高 垂直居中任何元素 逗号分离的列表 使用负nth-child选择元素 使用SVG图标 文本显示优化 在纯CSS幻灯片上使用max-h

零基础学WEB前端-CSS

CSS指层叠样式表(Cascading Style Sheets),CSS 是标准的布局语言,用来控制元素的尺寸.颜色.排版.CSS 由 W3C 发明,用来取代基于表格的布局.框架以及其他非标准的表现方法.样式 (style) 定义如何显示 HTML 元素:样式通常存储于样式表中:外部样式表存储于 CSS 文件中. CSS可以解决html代码对样式定义的重复,提高了后期样式代码的可维护性,并增强了网页的显示效果功能.简单一句话:CSS将网页内容和显示样式进行分离,提高了显示功能. 1.CSS基础

web前端—css面试题

1.CSS 选择符有哪些? 2.CSS 优先级的选择过程? 优先级复合就近原则,同权重的情况下有限选择最近的属性. 载入样式的话是以最后载入的定位为准. 优先级: !important > id > class > tag(important要优先于内联样式) 3.阐述一下CSS3的新增伪类. 4.如何居中 div?如何居中一个浮动元素?如何让绝对定位的div居中? div居中:给div一个宽度,然后添加margin: 0 auto;属性即可. 浮动元素居中: 绝对定位的div居中: 5

Bootstrap(Web前端CSS框架)

官方定义: Bootstrap is the most popular HTML, CSS, and JS framework for developing responsive, mobile first projects on the web. 即:Bootstrap 是最受欢迎的 HTML.CSS 和 JS 框架,用于开发响应式布局.移动设备优先的 WEB 项目. 百科定义: 简介:Bootstrap是Twitter推出的一个开源的用于前端开发的工具包,是一个CSS/HTML框架.Boot

web前端css定位position和浮动float

最近做了几个项目:配资公司,ecmal商城等,客户对前台要求都很高.所以,今天来谈谈css的基础,以及核心,定位问题. div.h1或p元素常常被称为块级元素.这意味着这些元素显示为一块内容,即“块框”.与之相反,span和h3等元素称为“行内元素”,这是因为它们的内容显示在行中,即“行内框”. 在这种情况下,这个框称为无名块框,因为它不与专门定义的元素相关联. 块级元素的文本行也会发生类似的情况.假设有一个包含三行文本的段落.每行文本形成一个无名框.无法直接对无名块或行框应用样式,因为没有可以

Bootstrap (Web前端CSS框架)

Bootstrap 是基于 HTML.CSS.JAVASCRIPT 的,它简洁灵活,使得 Web 开发更加快捷.它是由动态CSS语言less写成.Bootstrap 包的内容 基本结构:Bootstrap 提供了一个带有网格系统.链接样式.背景的基本结构. CSS:Bootstrap 自带以下特性:全局的 CSS 设置.定义基本的 HTML 元素样式.可扩展的 class,以及一个先进的网格系统. 组件:Bootstrap 包含了十几个可重用的组件,用于创建图像.下拉菜单.导航.警告框.弹出框等

web前端——CSS 02 选择器

css的选择器:1.基本选择器 2.高级选择器 基本选择器包含: 1.标签选择器标签选择器可以选中所有的标签元素,比如div,ul,li ,p等等,不管标签藏的多深,都能选中,选中的是所有的,而不是某一个,所以说 "共性" 而不是 ”特性“ body{ color:gray; font-size: 12px; } /*标签选择器*/ p{ color: red; font-size: 20px; } span{ color: yellow; } 2.id选择器# 选中id 同一个页面中

web前端——CSS 01 css的引入方式

引入css方式(重点掌握) 行内样式 内接样式 外接样式 3.1 链接式 3.1 导入式 css介绍 现在的互联网前端分三层: HTML:超文本标记语言.从语义的角度描述页面结构. CSS:层叠样式表.从审美的角度负责页面样式. JS:JavaScript .从交互的角度描述页面行为 CSS:Cascading Style Sheet,层叠样式表.CSS的作用就是给HTML页面标签添加各种样式,定义网页的显示效果.简单一句话:CSS将网页内容和显示样式进行分离,提高了显示功能. css的最新版本

web前端-css

1.1CSS 链接的四种状态: a:link --普通的.未被访问的链接 a:visited --用户已访问的链接 a:hover --鼠标指针位于链接的上方 a:active --链接被点击的时刻 这里我们需要注意的是这四个属性设置要遵循的顺序问题: a:hover 必须位于 a:link 和 a:visited 之后 a:active 必须位于 a:hover 之后 我们要在 link 属性中加入 text-decoration 属性,可以去掉下划线 1.2css轮廓 轮廓(outline)

web前端css总结

css主要是选择器和多条声明构成 每个声明由属性和值组成 选择器分为:派生选择器.id选择器.类选择器.属性选择器.伪类选择器.伪元素选择器 派生选择器允许根据文档的上下文关系来确定某个标签的样式 id选择器可以为特有id的html元素制定特定样式,每个元素都有不同的id,每个id只能指定一个元素 类选择器可以为多个元素制定一样的样式可多,可供多个元素共同使用 可以为拥有指定属性的 HTML 元素设置样式 伪类和伪元素用于向某些选择器添加特殊的效果 属性优先级: 在css中importart拥有