【CSS基础语法】CSS基础语法知识

CSS基础语法
前言
一、样式定义方式
  1.html
  2.css
二、选择器
  1.html
  2.css
三、颜色
  1.html
  2.css
四、文本
  1.html
  2.css
五、字体
  1.html
  2.css
六、背景
  1.html
  2.css
七、边框
  1.html
  2.css
八、元素展示格式
  1.html
  2.css
九、内边距与外边距
  1.html
  2.css
十、盒子模型
  1.html
  2.css
十一、位置
  1.html
  2.css
十二、浮动
  1.html
  2.css
十三、flex布局
  1.html
  2.css

前言
html类似于一个毛坯房骨架,css类似于给毛坯房进行装饰

代码文件整理:
static文件夹一般用来存放各种资源,比如图片、音频视频、css文件
index.html为骨架

css全称为层叠样式表,作用:修饰html标签

html与css:
在html标签中,最基础的就是div和span标签,其他绝大部分标签都是从这两个标签上扩展出来的,扩展的时候其实就是在div和span标签的基础上加了一些css样式
即有很多标签是在基础标签的基础之上加了一些css样式得到的,只不过这些样式很常用就把他们单独拿出来作为单独的标签使用

css与js:
同理:在css中有一些常用的固有属性,绝大部分属性都是用js实现出来,所以也把js中一些常用逻辑单独拿出来作为css的一些常用属性

html、css、js三者关系:
html最上层(表层)
css 较下层
js最深层(底层)

现在学的都是基础语法,基础语法一定要学,等以后写项目工程时其实都是用框架,就像在写程序是没有必要手写汇编一样

1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 7     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 8     <title>Document</title>
 9 </head>
10 
11 <body>
12     <!--
13          css有三种定义方式:
14          1.直接定义在标签的style属性中
15          2.定义在style标签中,通过选择器影响对应的标签。
16          3.定义在css样式文件中,通过选择器影响对应的标签。可以用link标签引入某些页面。
17 
18          第一种:行内样式表:
19          直接定义在标签的style属性中,作为一个标签的属性直接定义出来的
20          作用范围:仅对当前标签产生影响。(因为这种方式只能定义在某一个标签上面)
21      -->
22     <img width="300" src="/Learn2-css基础/static/images/mountain.jpg" alt="山">
23     <img src="/Learn2-css基础/static/images/mountain.jpg" alt="山" style="width: 300px;">
24 
25     <div>yxc</div>
26     <div style="width: 300px; height: 300px; background-color: lightblue;"></div>
27     <!-- 
28         css中style样式中width单位要加上px,1px就是1像素
29         而在h5中width属性可以不加px,默认为px
30      -->
31 
32 </body>
33 
34 </html>
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 7     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 8     <title>Document</title>
 9 
10     <!-- 
11         内部样式表:
12         定义在sty标签中,可以通过css选择器将某些标签设置成统一的样式 
13         作用范围:可以对同一个页面中多个元素产生影响
14         优点:定义一个样式可以应用于一个页面中的多个标签上
15         注意:
16         (1)如果只想修改其中的几个标签而不是全部标签,可以利用class属性,给标签起class名,css中通过class来选择
17         css中通过.class名的形式来修改调用
18         (2)同一个class中可以有多个类,中间只需要用空格隔开即可
19         (3)class也可以跨标签使用
20         (4)内部样式表可以分开定义,不一定只定义在一个标签style中,即可以定义多个style中
21         (5)style理论上最好定义在head标签里面,但其实定义在body中也没有影响,很灵活
22         
23     -->
24     <style>
25         img {
26             width: 200px;
27             height: 200px;
28             border-radius: 50%;
29         }
30     </style>
31 
32     <style type="text/css">
33         p {
34             width: 50px;
35             height: 50px;
36             background-color: lightgreen;
37         }
38 
39         .blue-p {
40             background-color: lightblue;
41         }
42     </style>
43 </head>
44 
45 <body>
46     <style>
47         .big {
48             width: 70px;
49             height: 70px;
50         }
51     </style>
52 
53     <img class="big" src="/Learn2-css基础/static/images/logo.png" alt="">
54     <img src="/Learn2-css基础/static/images/mountain.jpg" alt="">
55 
56     <p class="blue-p">1</p>
57     <p class="big">2</p>
58     <p class="blue-p big">3</p>
59     <p>4</p>
60 
61 </body>
62 
63 </html>
 1 <!DOCTYPE html>
 2 <html lang="en">
 3 
 4 <head>
 5     <meta charset="UTF-8">
 6     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 7     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 8     <title>Document</title>
 9     <!-- 
10         (1)如果想让样式同时应用到多个页面中,就要用外部样式表
11         (2)将这样式存到一个文件中,通过link标签把定义的样式表动态链接进来。通过href属性,type可写可不写
12         (3)也可以定义多个css样式表,因为如果网站变大之后,一个文件可能并不能把所有的样式都包含进来,代码多了很难维护。
13         (4)外部样式表可以应用于多个页面文件中
14         (5)优先级:html渲染器一般都是从前往后写,一行一行去执行
15         如果两个css文件同时修改了一个html标签,按照一行一行的执行顺序,后面的会把前面的覆盖掉
16      -->
17 
18     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.1.3style1.css" type="text/css">
19     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.1.3style2.css" type="text/css">
20 </head>
21 
22 <body>
23     <img class="big" src="/Learn2-css基础/static/images/logo.png" alt="">
24     <img src="/Learn2-css基础/static/images/mountain.jpg" alt="">
25 
26     <p class="blue-p">1</p>
27     <p class="big">2</p>
28     <p class="blue-p big">3</p>
29     <p>4</p>
30 </body>
31 
32 </html>

2.css

 1 p {
 2     width: 50px;
 3     height: 50px;
 4     background-color: lightgreen;
 5     /* css文件注释方式,可以注释单行 */
 6     /*
 7         也可以注释多行,与c++中注释类似 
 8      */
 9 }
10 
11 .blue-p {
12     background-color: lightblue;
13 }
14 
15 .big {
16     width: 70px;
17     height: 70px;
18 }

二、选择器

1.html

 1 <!-- 
 2     如何能够高效的选择出我们希望选择的标签呢?
 3     css帮我们实现了一推我们常用的选择器,不需要硬背。
 4     选择器的作用:让我们很方便地选择出来我们希望选择的标签。
 5  -->
 6 
 7 <!DOCTYPE html>
 8 <html lang="en">
 9 <head>
10     <meta charset="UTF-8">
11     <meta http-equiv="X-UA-Compatible" content="IE=edge">
12     <meta name="viewport" content="width=device-width, initial-scale=1.0">
13     <title>Document</title>
14 
15     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.2选择器style.css">
16 </head>
17 <body>
18     <div>div 1</div>
19     <div>div 2</div>
20     <div>div 3</div>
21     <div>div 4</div>
22     <div id="mydiv">div 5</div>
23     <div class="red-tag big-tag">div 6</div>
24     <div class="big-tag">div 7</div>
25     <div class="effect">div 8</div>
26     <a href="/Learn2-css基础/html/about1.html">about1</a>
27     <a href="/Learn2-css基础/html/about2.html">about2</a>
28     <a href="/Learn2-css基础/html/about3.html">about3</a>
29     <a href="/Learn2-css基础/html/about4.html">about4</a>
30     <button href="/Learn2-css基础/html/about1.html">about1</button>
31     <button href="/Learn2-css基础/html/about2.html">about2</button>
32     <button href="/Learn2-css基础/html/about3.html">about3</button>
33     <button href="/Learn2-css基础/html/about4.html">about4</button>
34     <input type="text" name="" id="">
35 
36 
37 
38     
39     <p>p 1</p>
40     <p>p 2</p>
41     <p>p 3</p>
42     <p>p 4</p>
43     <p id="myp">p 5</p>
44     <p class="red-tag">p 6</p>
45     <p>p 7</p>
46     <p>p 8</p>
47     <p>p 9</p>
48     <a href="#myp1">我的标签</a>
49     <p>p 10</p>
50     <p>p 11</p>
51     <p id="myp1">p 12</p>
52 
53     <div class="real">div 1</div>
54     <div class="big">div 2</div>
55     <div class="big real">div 3</div>
56     <div></div>
57 
58     <p>p 1</p>
59     <p id="myp2" class="big">p 2</p>
60     <p>p 3</p>
61     <p>p 4</p>
62 
63     <ul>
64         <li>1
65             <ul>
66                 <li>1.1</li>
67                 <li>1.2</li>
68                 <li>1.3</li>
69             </ul>
70         </li>
71         <li>2</li>
72         <li>3</li>
73     </ul>
74 
75     <input type="text" name="">
76     <input type="number" name="" id="">
77 
78 
79 
80     <p>锄禾日当午,</p>
81     <p>汗滴禾下土。</p>
82     <p>谁知盘中餐,</p>
83     <p>粒粒皆辛苦。</p>
84         
85     <h1>悯农</h1>
86     <h1>咏柳</h1>
87     <h1>枫桥夜泊</h1>
88     <h1>滕王阁序</h1>
89     
90 </body>
91 </html>

2.css

  1 /*
  2 1.标签(元素)选择器:
  3 */
  4 div {
  5     width: 100px;
  6     height: 100px;
  7     background-color: lightblue;
  8     margin-bottom: 10px;
  9 }
 10 
 11 p {
 12     width: 50px;
 13     height: 50px;
 14     background-color: lightgreen;
 15     /* p标签自带外边距,div默认不带外边距 */
 16 }
 17 
 18 
 19 /*
 20 2.ID选择器:
 21 (1)每个标签都可以设置id属性名,一般同一个页面中给标签设置的id是不同的
 22 (2)形式:#+标签id的名字。(一般与id相关的都是用#号)
 23 */
 24 #mydiv {
 25     background-color: lightcoral;
 26 }
 27 
 28 #myp {
 29     background-color: lightsalmon;
 30 }
 31 
 32 /*
 33 3.类选择器:
 34 (1)第一种和第二种不常用,最常用的是第三种类选择器,class非常灵活,一般做项目只用前四种就够了
 35 (2)每一个标签里都可以定义class属性,class里可以存若干个用空格隔开的类名
 36 (3)class与id的区别:
 37 id和class在逻辑上没有任何区别,所有的区别都是人为定义的
 38 ①同一页面中的每个标签设置id名一般来讲是唯一的,但多个标签可以用同一个class
 39 ②class里可以存若干个用空格隔开的类名:同一个标签同时可以具有多个class,但一般只能具有一个id
 40 (4)形式:.+类名(一般与类有关的都加.)
 41 .+类名表示类,#+id名表示id,什么都不加表示标签
 42 (5)class渲染时的顺序:
 43 与声明顺序无关,与css中class的定义顺序有关。按顺序表达最后一个
 44 */
 45 .red-tag {
 46     background-color: red;
 47 }
 48 
 49 .big-tag {
 50     width: 120px;
 51     height: 120px;
 52 }
 53 
 54 /*
 55 4.伪类选择器
 56 又叫状态选择器
 57 
 58 (1)链接伪类选择器
 59 :hover:鼠标悬停时的样式
 60 :link:链接访问前的样式
 61 :visited:链接访问后的样式
 62 :active:鼠标点击后长按时的样式
 63 :focus:聚焦后的样式
 64 
 65 (2)位置伪类选择器:
 66 :nth-child(n):选择是其父标签第n个子元素的所有元素。
 67 
 68 (3)目标伪类选择器:
 69 :target:当url指向该元素时生效。
 70 */
 71 .effect:hover {
 72     transform: scale(1.2);
 73     /*鼠标方上去之后变大多少倍*/
 74     transition: 200ms;
 75     /*鼠标方上去之后实现渐变的效果,表示用多长时间渐变过去*/
 76 }
 77 
 78 #mydiv:hover {
 79     /*伪类型选择器可以加到任意选择器后面*/
 80     background-color: lightgreen;
 81     transition: 2000ms;
 82 }
 83 
 84 a:link {
 85     color: red;
 86 }
 87 
 88 a:visited {
 89     color: green;
 90 }
 91 
 92 a:hover {
 93     color: orange;
 94 }
 95 
 96 a:active {
 97     color: purple;
 98 }
 99 
100 button:link {
101     color: red;
102     background-color: blue;
103     /* color是字体颜色,background-color是背景颜色 */
104 }
105 
106 button:visited {
107     color: green;
108 }
109 
110 button:hover {
111     color: orange;
112     background-color: aquamarine;
113 }
114 
115 button:active {
116     color: purple;
117     background-color: chartreuse;
118 }
119 
120 
121 input:focus {
122     /*focus聚焦,每个页面都有一个光标,就是按键盘的时候光标出现在什么地方,光标所在的元素被称为聚焦,聚焦常与输入框input常用
123     悬停与聚焦的区别:
124     聚焦需要鼠标或键盘点击,悬停不用
125     */
126     background-color: lightblue;
127     width: 100px;
128 }
129 
130 input:hover {
131     transform: scale(1.2);
132 }
133 
134 
135 p:nth-child(24) {
136     /* 
137     nth-child()是一状态,即bool函数,依次判断每一个p是不是父节点body的第n个儿子,如果是就执行下面css样式
138     注意父节点是body,下标从1开始
139     不要理解为选择第n个p标签,即父节点body的第n个儿子(虽然是这样),要理解为是状态,是一个bool函数判断是不是满足这个条件
140     */
141     background-color: lightslategray;
142 }
143 
144 
145 p:nth-child(2n+1) {
146     /* 
147     an+b:an+b必须是正整数
148     odd:表示奇数块
149     even:表示偶数块 
150     */
151     background-color: blue;
152 }
153 
154 p:target {
155     transform: scale(1.2);
156     color: orange;
157     transition: 2s;
158 }
159 
160 
161 /*
162 5.复合选择器
163 有可能存在多个标签公用同一个状态,没有必要定义很多遍,使用复合选择器可以实现
164 element1, element2:同时选择元素element1和元素element2。
165 element.class:选则包含某类的element元素。
166 element1 + element2:选择紧跟element1的element2元素。
167 element1 element2:选择element1内的所有element2元素。
168 element1 > element2:选择父标签是element1的所有element2元素。
169 
170  */
171 
172 div,
173 p {
174     background-color: lightblue;
175 }
176 
177 div:hover,
178 p:hover {
179     background-color: lightblue;
180 }
181 
182 
183 div.big {
184     transform: scale(1.2);
185 }
186 
187 
188 div.big.real {
189     /* 
190     .也可以串联,只有同时满足big和real才能执行
191     以下三种等价
192      */
193     transform: scale(1.2);
194 }
195 
196 .big.real {
197     /* 不加div也一样,与上面那个等价 */
198     transform: scale(1.2);
199 }
200 
201 #myp2.big.real {
202     transform: scale(1.2)
203 }
204 
205 div+p {
206     background-color: lightgreen;
207     /* +表示紧跟在谁的后面才会执行 */
208 }
209 
210 p+p {
211     background-color: brown;
212 }
213 
214 #myp2+p {
215     background-color: black;
216 }
217 
218 li ul li {
219     /* 表示如果一个li他的祖先节点是li的话就会触发这个样式,不一定是父节点*/
220     color: red
221         /* 如果某一个样式的字体颜色变了,那么他的字体颜色是可以继承给它的子节点的 */
222         /* 基于双指针的贪心算法匹配的 */
223 }
224 
225 li>ul>ul {
226     /* 表示如果一个ul他的父节点是li的话就会触发这个样式*/
227     color: red
228 }
229 
230 
231 /*
232 6.通配符选择器
233 *:选择所有标签
234 [attribute]:选择具有某个属性的所有标签
235 [attribute=value]:选择attribute值为value的所有标签
236 
237  */
238 * {
239     /* *就是选择所有标签 */
240     font-size: 24px;
241 }
242 
243 input[id] {
244     background-color: lightblue;
245 }
246 
247 input:id {
248     background-color: lightblue;
249     /* 与上面等价 */
250 }
251 
252 input[type=text] {
253     /* 按照属性选择标签 */
254     background-color: lightblue;
255 }
256 
257 
258 /* 
259 7.伪元素选择器
260 将特定内容当做一个元素,选择这些元素的选择器被称为伪元素选择器。
261 
262 ::first-letter:选择第一个字母
263 ::first-line:选择第一行
264 ::selection:选择已被选中的内容
265 ::after:可以在元素后插入内容
266 ::before:可以在元素前插入内容
267 */
268 
269 p::first-letter {
270     color: red;
271     font-size: 110%;
272 }
273 
274 p::selection {
275     color: yellow;
276     background-color: blueviolet;
277 }
278 
279 h1::before {
280     content: "《";
281     color: red;
282 }
283 
284 h1::after {
285     content: "》";
286 
287 }
288 
289 /*
290  样式渲染优先级:
291  不必深究这些特殊情况,一般不会用到
292  越具体越优先,执行越晚越优先
293  */

三、颜色

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.3颜色style.css" type="text/css">
 9 
10 </head>
11 <body>
12     <p>1</p>
13     <p>2</p>
14     <p>3</p>
15     <p>4</p>
16 
17 </body>
18 </html>

  2.CSS

 1 /* 
 2 1.预定义的颜色值
 3 black、white、red、green、blue、lightblue等。
 4 
 5 2.16进制表示法
 6 使用6位16进制数表示颜色,例如:#ADD8E6。
 7 其中第1-2位表示红色,第3-4位表示绿色,第5-6位表示蓝色。
 8 简写方式:#ABC,等价于#AABBCC。
 9 
10 3.RGB表示法
11 rgb(173, 216, 230)。
12 其中第一个数表示红色,第二个数表示绿色,第三个数表示蓝色。
13 
14 4.RGBA表示法
15 rgba(173, 216, 230, 0.5)。
16 前三个数同上,第四个数表示透明度。
17 
18 取色方式
19 网页里的颜色,可以在chrome的调试模式下获取
20 其他颜色可以使用QQ的截图软件:
21 直接按c键,可以复制rgb颜色值
22 按住shift再按c键,可以复制16进制颜色值
23 
24 */
25 p {
26     width: 50px;
27     height: 50px;
28 }
29 
30 p:nth-child(1) {
31     background-color: lightblue;
32 }
33 
34 p:nth-child(2) {
35     background-color: #add8e6;
36     color: #ABC
37         /*#AABBCC的简写形式*/
38 }
39 
40 p:nth-child(3) {
41     background-color: rgb(173, 216, 230);
42 }
43 
44 p:nth-child(4) {
45     background-color: rgba(173, 216, 230, 0.5);
46 
47 }

四、文本

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.4文本style.css" type="text/css">
 9 
10 </head>
11 <body>
12     <h4>悯农</h4>
13     <div class="mydiv">
14         <p>锄禾日当午,</p>
15         <p>汗滴禾下土。</p>
16         <p>谁知盘中餐,</p>
17         <p>粒粒皆辛苦。</p>
18     </div>
19 
20     <div style="font-size: 2em;">
21         第一层
22         <div style="font-size: 2em;">
23             第二层
24             <div style="font-size: 2em;">
25                 第三层
26             </div>
27         </div>
28     </div>
29 
30     <div style="font-size: 2rem;">
31         第一层
32         <div style="font-size: 2rem;">
33             第二层
34             <div style="font-size: 2rem;">
35                 第三层
36             </div>
37         </div>
38     </div>
39 
40     <div class="mydiv1">
41 
42     </div>
43 
44     <div class="mydiv2">
45         <p>锄禾日当午,</p>
46         <p>汗滴禾下土。</p>
47         <p>谁知盘中餐,</p>
48         <p>粒粒皆辛苦。</p>
49     </div>
50 
51    
52     <div class="mydiv3">
53         <p>锄禾日当午,锄禾日当午,锄禾日当午,
54             锄禾日当午,锄禾日当午,锄禾日当午,
55             锄禾日当午,锄禾日当午,锄禾日当午,
56             锄禾日当午,锄禾日当午,锄禾日当午,
57         </p>
58         <p>汗滴禾下土。汗滴禾下土。汗滴禾下土。
59             汗滴禾下土。汗滴禾下土。汗滴禾下土。
60             汗滴禾下土。汗滴禾下土。汗滴禾下土。
61             汗滴禾下土。汗滴禾下土。汗滴禾下土。
62         </p>
63         <p>谁知盘中餐,</p>
64         <p>粒粒皆辛苦。</p>
65     </div>
66 
67     <a href="/about.html">About</a>
68 </body>
69 </html>

  2.CSS

 1 h4 {
 2     text-align: center;
 3     /*  
 4     text-align 相当于word中的对齐
 5     左右对齐:除了最后一行之外,左右都对齐
 6     文字对齐是可以继承的,子标签可以继承父标签的对齐方式
 7     */
 8 
 9 }
10 
11 .mydiv {
12     text-align: center;
13     font-size: 20px;
14 }
15 
16 /*
17 网页中常用的长度单位:
18 px:绝对值,屏幕上一个像素点的长度,第一层默认是16px
19 以下都是相对值,用的比较多,
20 %    相对于父元素的百分比
21 em    相对于当前元素的字体大小,em永远都是相对值,所以只需要修改初始值,就可以让整个页面等比例放大缩小了
22 rem    相对于根元素的字体大小
23 vw    相对于视窗宽度的百分比,把浏览器窗口平均分成100份,1vw表示窗口宽度的百分之一
24 vh    相对于视窗高度的百分比,1vh表示窗口高度的百分之一,vw和vh可以实现与浏览器等比例缩放
25 
26  */
27 
28 .mydiv {
29     text-align: center;
30     font-size: 200%;
31 }
32 
33 .mydiv1 {
34     width: 50vw;
35     height: 50vw;
36     background-color: lightblue;
37 }
38 
39 .mydiv2 {
40     text-align: center;
41     line-height: 200px;
42     /* 
43     line-height是行高,行高就是每一行的高度,可以认为是行与行之间的距离
44     a*b:a是宽度,b是高度 
45     行高常应用于字体竖直居中,因为字在渲染会默认放到行的中间
46     */
47     background-color: lightblue;
48     height: 200px;
49 
50     letter-spacing: 1.5em;
51     /* 字间距,字和字之间的距离,1.5表示字和字之间隔着1.5个字的距离*/
52 }
53 
54 .mydiv3 {
55     text-indent: 2em;
56     /* 缩进常应用于段落,此时单位常用em */
57 }
58 
59 .mydiv3>p:nth-child(1) {
60     text-decoration: underline dotted;
61     /* 
62     文本修饰,有下划线等很多
63     常应用于删掉链接中的下划线 
64     */
65     text-shadow: 3px 3px 2px grey;
66     /*  
67     实现阴影效果
68     有四个参数:阴影效果x方向的偏移量,阴影效果y方向的偏移量,阴影模糊r半径,color颜色
69     注意css中的x,y的正方向,x向右为正方向,y向下为正方向与数中相反
70     r可以省略,不写就是不模糊
71     可以同时加多个阴影效果,即一个字可以有任意多个阴影效果,css中所有并列的项都是用空格隔开的
72     */
73     text-shadow: -5px -5px 2px gray, 5px -5px 2px red;
74 
75 }
76 
77 a {
78     text-decoration: none;
79 
80 }

五、字体

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/Learn2-css基础/static/css/2.5字体style.css" type="text/css">
 9 </head>
10 <body>
11     <h4>悯农</h4>
12     <div class="mydiv">
13         <p>锄禾日当午,</p>
14         <p>汗滴禾下土。</p>
15         <p>谁知盘中餐,</p>
16         <p>粒粒皆辛苦。</p>
17     </div>
18 
19     <pre>
20 #include
21 using namespace std;
22 int main()
23 {
24     int a,b;
25     cin >> a >> b;
26     cout << a+b;
27     return 0;
28 }
29     </pre>
30 </body>
31 </html>

  2.CSS

 1 h4 {
 2     text-align: center;
 3 }
 4 
 5 .mydiv {
 6     text-indent: 3em;
 7 }
 8 
 9 .mydiv>p:nth-child(1) {
10     font-size: 1.5rem;
11     /* 字体型号,默认是16px */
12     font-style: italic;
13     /* 字体样式是否斜体:italic是斜体,normal是正常*/
14     font-weight: 1000;
15     /* 字体粗细:可以填1~1000中的值,没有单位,数越大越粗,也可以填一些文字选项,bolder,lighter等等*/
16     font-family: serif;
17     /* 字体种类:选项都不用倍,用啥去MDN官网查就行,比如等宽字体,带衬线字体,宋体... */
18     /* 字体也可以自己上传 */
19     color: blue;
20     /* color就是字体颜色 */
21 }
22 
23 pre {
24     font-family: monospace;
25 }

六、背景

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.6背景style.css" type="text/css">
 9 
10 </head>
11 <body>
12     <div class="mydiv">
13 
14     </div>
15 
16     <div class="mydiv1">
17 
18     </div>
19 
20     <!-- 小技巧:div*5 可以同时敲出五个并列的div -->
21     <div></div>
22     <div></div>
23     <div></div>
24     <div></div>
25     <div></div>
26 
27     <div class="mydiv2">
28 
29     </div>
30 
31     <div></div>
32     <div></div>
33     <div></div>
34     <div></div>
35     <div></div>
36 
37 </body>
38 </html>

  2.CSS

 1 /*
 2 背景是说某一个标签的底色是什么 
 3  */
 4 
 5 .mydiv {
 6     width: 200px;
 7     height: 200px;
 8     background-color: lightblue;
 9     /* 通过backgound-color给背景设置背景颜色 */
10 
11     background-image: url(/static/images/mountain.jpg);
12     background-image: linear-gradient(rgba(0, 0, 255, 0.5));
13     /* 
14     引入一个图片作为背景,背景图片比背景颜色优先级高,即背景图片的图层一定在背景颜色图层的上面
15     也可以由渐变色替换图片
16      */
17     background-size: 50px 50px;
18     background-size: 50% 50%;
19     /*
20     设置背景背景图片的大小,宽跟高度
21     background-size 的cover选项可以让图占满div 
22     */
23     background-repeat: no-repeat;
24     /* 
25     设置背景图片要不要重复
26     背景图像可以沿着水平轴,垂直轴,两个轴重复,或者根本不重复。
27     repeat-x只重复行
28     repeat-y只重复列
29     */
30 
31     background-position: 50px 10px;
32     /* 
33     背景图片偏移量:x向右,y向下 
34     如果x,y有一维不写,这一维会默认居中
35     background-position:50px 等价于background-position:50px center
36     也可以写成rigth和left控制左右,top和bottom控制上下
37     */
38     background-position: right bottom;
39 }
40 
41 .mydiv1 {
42 
43     /* 
44     一张图里可以加很多图片,不一定只加一张图片 
45     多个图片也可以覆盖有优先级,定义越靠前的,图片越靠上
46     */
47     width: 200px;
48     height: 200px;
49     background-color: lightblue;
50     background-image: url(/static/images/mountain.jpg), url(/static/images/logo.png);
51     background-size: 100px 200px, 100px 200px;
52     background-repeat: no-repeat;
53     background-position: left top, 100px top;
54 }
55 
56 div {
57     height: 200px;
58 }
59 
60 .mydiv2 {
61 
62     /* 
63     一张图里可以加很多图片,不一定只加一张图片 
64     多个图片也可以覆盖有优先级,定义越靠前的,图片越靠上
65     */
66     width: 200px;
67     height: 200px;
68     background-color: lightblue;
69     background-image: url(/static/images/mountain.jpg), url(/static/images/logo.png);
70     background-size: 100px 200px, 100px 200px;
71     background-repeat: no-repeat;
72     background-position: left top, 100px top;
73     background-attachment: fixed;
74     /*  scroll随着div一起滚 fixed位置固定,不随着div滚 */
75     opacity: 0.2;
76     /* 透明度:可以设置元素的透明度,不仅可以把背景变透明,也可以让图片变透明 */
77 
78 }

七、边框

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.7边框style.css" type="text/css">
 9 </head>
10 <body style="margin: 0;">
11         <img src="/static/images/mountain.jpg" alt="">
12         <div></div><br>
13         <div></div><br>
14         <div></div><br>
15         <div></div><br>
16         <div></div><br>
17     </div>
18 
19     <table>
20         <tbody>
21             <!-- 快捷键:(tr>td*3)*3 -->
22             <tr>
23                 <td></td>
24                 <td></td>
25                 <td></td>
26             </tr>
27             <tr>
28                 <td></td>
29                 <td></td>
30                 <td></td>
31             </tr>
32             <tr>
33                 <td></td>
34                 <td></td>
35                 <td></td>
36             </tr>
37            
38         </tbody>
39     </table>
40    
41 </body>
42 </html>

  2.CSS

 1 div {
 2     width: 100px;
 3     height: 100px;
 4     background-color: lightblue;
 5 
 6     border-style: solid dotted inset;
 7     /* 设置边框的样式:solid是实现,dotted是点 */
 8     /*注意css边界可以写四个方向: 
 9     可以按照上右下左的顺序来写的
10     如果只写一个默认是四个方向都是同一个格式,
11     如果写两项就是上下和左右
12     (其实上是按照上下左右的顺序来写,没写的那一项就取对边值) 
13     */
14 
15     border-width: 2px 4px 6px;
16     /* 设置边框的粗细 */
17 
18     border-color: red green blue;
19     /* 设置边框颜色 */
20 
21     border-radius: 5px 0 0 0;
22     /*设置外边框的边角,很常用,5px表示边角半径的长度 */
23 
24 }
25 
26 img {
27     width: 100px;
28     height: 100px;
29     border-radius: 50%;
30 }
31 
32 td {
33     border-style: solid;
34     border-width: 3px;
35     width: 20px;
36     height: 20px;
37 }
38 
39 table {
40     border-style: solid;
41     border-width: 3px;
42     border-collapse: collapse;
43     /* 把table元素的边框都重合到一块,separate 是分开*/
44 }

八、元素展示格式

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.8元素展现格式style.css" type="text/css">
 9 </head>
10 <body style="margin: 0;">
11 
12     <!-- 
13         display:展示格式
14         一般的标签分为两大种,一种是div衍生过来的,一种是span衍生过来的,还有另一种这前两种结合
15         (1)block:块状标签(元素) div
16         独占一行
17         width、height、margin(外边距)、padding(内边距)均可控制
18         width默认100%。
19         (2)inline:行内标签 span
20         可以共占一行,除非占满一行才会换行
21         width与height无效,水平方向的margin与padding有效,竖直方向的margin与padding无效
22         width默认为本身内容宽度
23         (3)inline-block:行内-块状标签 img
24         可以共占一行
25         width、height、margin、padding均可控制
26         width默认为本身内容宽度
27      -->
28     <div>abc</div>
29     <div>abc</div>
30     <div>abc</div>
31     <br>
32 
33     <span>第一个元素</span>
34     <span>第二个元素</span>
35 
36     <img src="/static/images/mountain.jpg" alt="">
37     <img src="/static/images/mountain.jpg" alt="">
38     <img src="/static/images/mountain.jpg" alt="">
39 
40     <div class="mydiv">
41         锄禾日当午,汗滴禾下土。谁知盘中餐,粒粒皆辛苦。
42     </div>
43 
44     <div class="mydiv1">
45 #include
46 using namespace std;
47 int main()
48 {
49     int a,b;
50     cin >> a >> b;
51     cout << a + b ;
52     return 0;
53 }    
54     </div>
55 </body>
56 </html>

  2.CSS

 1 div {
 2     background-color: lightblue;
 3     width: 100px;
 4     height: 100px;
 5     margin: 10px;
 6     /* 外边距可以认为是距离周围其他元素的距离 */
 7     padding: 20px;
 8     /* 内边距可以认为是内部的元素距离边框的距离,可以改变整个元素的大小 */
 9 }
10 
11 span {
12     background-color: lightblue;
13     width: 500px;
14     height: 200px;
15     /* 发现上面的修改没有任何改变 */
16 
17     margin-top: 10px;
18     padding-top: 10px;
19     /* 发现上面的修改没有改变,水平方向的margin与padding有效,竖直方向的margin与padding无效*/
20 
21     margin-left: 10px;
22     padding-left: 10px;
23 
24 
25 }
26 
27 span {
28 
29     display: inline-block;
30     /* 可以强制修改为别的类型标签,所以三类标签之间可以相互转化 */
31     background-color: lightblue;
32     width: 500px;
33     height: 200px;
34 
35     margin-top: 10px;
36     padding-top: 10px;
37 
38 
39     margin-left: 10px;
40     padding-left: 10px;
41 
42 
43 }
44 
45 img {
46     width: 50px;
47     height: 100px;
48 }
49 
50 .mydiv {
51     width: 100px;
52     height: 100px;
53     background-color: lightblue;
54     white-space: nowrap;
55     /* white-space处理元素中的空白和换行:
56     nowrap就是不换行 */
57 
58 
59     overflow-x: hidden;
60     overflow-y: scroll;
61     /* 滚轮,hidden是隐藏,scroll是出现,如果什么都不写默认是auto,同时控制直接可以用overflow*/
62     text-overflow: ellipsis;
63     /* 长度如果超出行宽的话,就用三个点代替 */
64 }
65 
66 .mydiv1 {
67     width: 200px;
68     height: 200px;
69     background-color: lightblue;
70     white-space: pre;
71     /* 所以pre也是在div的基础上扩展出来的 */
72 }

九、内边距与外边距

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=S, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.9内边距与外边距.css" type="text/css">
 9 </head>
10 <body style="margin: 0;">
11 
12     <!--
13         content:内容区
14         padding:内边距,内容区距离边框的距离
15         border:边框
16         margin:外边距,边框距离周围元素的距离
17      -->
18 
19      <!-- 
20         
21       -->
22     <div class="div-outer">
23         <div class="div-inner"></div>
24         <div class="div-inner-2"></div>
25     </div>
26 </body>
27 </html>

  2.CSS

 1 /* 
 2 1.外边距 margin:
 3 margin属性为给定元素设置所有四个(上下左右)方向的外边距属性。
 4 可以接受1~4个值(上、右、下、左的顺序)
 5 可以分别指明四个方向:margin-top、margin-right、margin-bottom、margin-left
 6     css边界可以写四个方向: 
 7     可以按照上右下左的顺序来写的
 8     如果只写一个默认是四个方向都是同一个格式,
 9     如果写两项就是上下和左右
10     (其实上是按照上下左右的顺序来写,没写的那一项就取对边值) 
11 可取值:
12 ①length:固定值
13 ②percentage:相对于包含块的宽度,以百分比值为外边距。
14 ③auto:让浏览器自己选择一个合适的外边距。有时,在一些特殊情况下,该值可以使元素居中。auto可以实现水平居中,上下居中实现不了
15 
16 
17 
18 */
19 
20 .div-outer {
21     width: 300px;
22     height: 300px;
23     background-color: lightblue;
24     margin: 50px;
25 
26     /* 外边距的两种边界问题 */
27     /* 
28     边界问题1:
29     父元素与后代元素:当父元素没有上边框和padding时,后代元素的margin-top会溢出,溢出后父元素的margin-top会与后代元素取最大值。
30     解决方法:
31     子元素的margin-top连带影响父元素的上外边距解决方法
32     ① 父元素加一个边框:border: 1px solid;
33     ② 父元素加内边距:padding-top: 1px;
34     ③ 父元素加上overflow属性 overflow: hidden;
35     ④ 在父元素前面加一个空内容:.div-outer::before {content: “”;display: table;}
36     */
37 }
38 
39 .div-outer::before {
40     content: "";
41     display: table;
42 }
43 
44 
45 .div-inner {
46     width: 100px;
47     height: 100px;
48     background-color: red;
49     margin: 20px auto;
50     /* auto可以实现水平居中,上下居中实现不了 */
51 
52     margin-bottom: 20px;
53     margin-left: 20px;
54 }
55 
56 .div-inner-2 {
57     width: 100px;
58     height: 100px;
59     background-color: darkgreen;
60     margin-top: 30px;
61     margin-left: 30px;
62     /* 
63     边界问题2:
64     发现两个元素的外边距上下发生了重叠,此时取外边距的最大值。
65     这种外边距重叠的情况只出现在上下,左右外边距是不会出现外边距重叠的情况的
66     解决方法:
67     为了不出现这种歧义的情况,尽可能只定义元素下外边距就可以了,最好不要上下边距同时定义,同理左右边距也是这样
68     */
69 }
70 
71 
72 /* 
73 2.内边距:padding
74 padding CSS 简写属性控制元素所有四条边的内边距区域。
75 可以接受1~4个值(上、右、下、左的顺序)
76 可以分别指明四个方向:padding-top、padding-right、padding-bottom、padding-left
77 可取值:
78 ①length:固定值
79 ②percentage:相对于包含块的(即父级元素的)宽度,以百分比值为内边距。
80 
81 注意:元素的大小是和内边距相关的,即元素的宽度和高度都会加上内边距
82 即 width=content+ padding +border
83 */
84 
85 
86 .div-outer {
87 
88     padding-top: 20px;
89     padding-left: 30px;
90     padding: 20px 0 0 30px;
91 }

十、盒子模型

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.10盒子模型style.css" type="text/css">
 9 </head>
10 <body style="margin: 0;">
11     <div class="div-outer">
12         <div class="div-inner">
13             123
14         </div>
15     </div>
16 </body>
17 </html>

  2.CSS

 1 /* 
 2 一个元素有以下边界属性:
 3 content:内容区
 4 padding:内边距,内容区距离边框的距离
 5 border:边框
 6 margin:外边距,边框距离周围元素的距离
 7 
 8 元素是由:content+ padding +border 构成
 9 内容是由:content 构成
10 */
11 
12 /* 
13 盒子模型:box-sizing
14 CSS 中的 box-sizing 属性定义了 user agent 应该如何计算一个元素的总宽度和总高度。
15 增加
16 content-box:是默认值,设置border和padding均会增加元素的宽高。
17 border-box:设置border和padding不会改变元素的宽高,而是挤占内容区域。
18 */
19 
20 .div-outer {
21     width: 300px;
22     height: 400px;
23     background-color: lightblue;
24     padding: 20px 0 0 30px;
25 }
26 
27 .div-outer::before {
28     content: "";
29     display: table;
30 }
31 
32 .div-inner {
33     width: 100px;
34     height: 100px;
35     background-color: darkred;
36     color: white;
37     box-sizing: border-box;
38     padding: 20px 0 0 10%;
39     border: 10px solid black;
40 }

十一、位置

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.11位置style.css" type="text/css">
 9 </head>
10 <body style="margin: 0;">
11     <div class="div-outer">
12         <div class="div-inner-1">
13             1
14         </div>
15         <div class="div-inner-2">
16             2
17         </div>
18         <div class="div-inner-3">
19             3
20         </div>
21         <div class="div-inner-4">
22             回到顶部
23         </div>
24     </div>
25 </body>
26 </html>

  2.CSS

 1 /* 
 2 position:指定一个元素在文档中的定位方式(右四种定位类型,五种取值)
 3 (1)static:默认定位,如果不设置的话,默认为static类型,即位置是从上往下一行一行正常摆
 4 该关键字指定元素使用正常的布局行为,即元素在文档常规流中当前的布局位置。此时 top, right, bottom, left 和 z-index 属性无效。
 5 (2)relative:相对定位,相对于初始位置(static位置下)可以做上下左右四个方向的偏移
 6 (3)absolute:绝对定位,相对于上一个非static类型的块元素定位,固定在文档的某一个位置上,所以元素的位置在屏幕滚动时会随之改变
 7 (4)fixed:绝对定位,又叫固定定位(窗口定位)相对于上一个非static类型的块元素定位,固定在屏幕视窗上,跟文档是脱离的,所以元素的位置在屏幕滚动时不会改变
 8 (5)sticky:粘性定位,元素根据正常文档流进行定位,然后相对它的最近滚动祖先进行偏移,不偏移的话跟static是一样的
 9 */
10 .div-outer {
11     width: 300px;
12     height: 3000px;
13     background-color: lightblue;
14     padding: 20px 0 0 30px;
15 }
16 
17 .div-outer::before {
18     content: "";
19     display: table;
20 }
21 
22 .div-inner-1 {
23     width: 100px;
24     height: 100px;
25     background-color: darkred;
26     color: white;
27     margin: 10px;
28     display: inline-block;
29 }
30 
31 .div-inner-2 {
32     width: 100px;
33     height: 100px;
34     background-color: darkgreen;
35     color: white;
36     margin: 10px;
37     display: inline-block;
38     position: relative;
39     top: 30px;
40     left: -100px;
41 }
42 
43 .div-inner-3 {
44     width: 100px;
45     height: 100px;
46     background-color: yellow;
47     color: white;
48     margin: 10px;
49     display: inline-block;
50     position: absolute;
51     top: 100px;
52     left: 20px;
53 }
54 
55 .div-inner-4 {
56     width: 30px;
57     height: 100px;
58     background-color: lightcoral;
59     color: white;
60     margin: 10px;
61     display: inline-block;
62     position: fixed;
63     top: 200px;
64     right: 0;
65 }

十二、浮动

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.12浮动style.css" type="text/css">
 9 
10 </head>
11 <body style="margin: 0;">
12     <div class="div-outer">
13         <div class="div-inner-1">
14             1
15         </div>
16         <div class="div-inner-2">
17             2
18         </div>
19         <div class="div-inner-3">
20             3
21         </div>
22         <div class="div-inner-4">
23             
24         </div>
25     </div>
26 </body>
27 </html>

  2.CSS

 1 /* 
 2 浮动:就是让某一块浮起来
 3 浮动的元素,不再占用空间,会脱离普通文档流层,且浮动元素的层级要高于普通元素
 4 (1)应用:如果想让不同的div放在同一行时,并且中间不想有空隙时,
 5 可以设置改变其与元素展现格式display:inline-block,但这种中间还是会有间距空隙
 6 可以直接设置float属性,float:left是左浮动,就是左对齐
 7 (2)注意:
 8 clear:清除浮动的影响
 9 left:清除左侧浮动。
10 right:清除右侧浮动。
11 both:清除左右两侧浮动
12 
13 理解:网页布局是分层的,分三层
14 1.最底层:普通文档流
15 不加float时,默认为普通文档流,即一个网页body
16 普通文档流中是分块级和内联的。
17 2.中间层:浮动层
18 元素浮动,设置float以后会提升到浮动层
19 所有浮动层的元素默认横向排列
20 浮动层中不分块级和内联,都可以定义宽高,都是横向排列。
21 3.最高层:定位层
22 设置postiton后就在定位层了
23 
24 什么时候要清除浮动?
25 1.子级浮动,父级一定要清除浮动
26 2.有时,你可能想要强制元素移至任何浮动元素下方。
27 比如说,你可能希望某个段落与浮动元素保持相邻的位置,但又希望这个段落从头开始强制独占一行。
28 
29 如何清除浮动?
30 1.overflow:hidden
31 2.clear:both
32 */
33 .div-outer {
34     width: 100%;
35     height: 3000px;
36     background-color: lightblue;
37 
38 }
39 
40 .div-outer::before {
41     content: "";
42     display: table;
43 }
44 
45 .div-inner-1 {
46     width: 100px;
47     height: 100px;
48     background-color: darkred;
49     color: white;
50 
51     float: left;
52 
53 }
54 
55 .div-inner-2 {
56     width: 100px;
57     height: 100px;
58     background-color: darkgreen;
59     color: white;
60 
61     float: left;
62 }
63 
64 .div-inner-3 {
65     width: 100px;
66     height: 100px;
67     background-color: yellow;
68     color: white;
69 
70     float: left;
71 
72 }
73 
74 .div-inner-4 {
75     width: 300px;
76     height: 300px;
77     background-color: black;
78     position: relative;
79     z-index: 3;
80     clear: both;
81 
82 }

十三、flex布局

  1.html

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <meta http-equiv="X-UA-Compatible" content="IE=edge">
 6     <meta name="viewport" content="width=device-width, initial-scale=1.0">
 7     <title>Document</title>
 8     <link rel="stylesheet" href="/static/css/2.13flex布局style.css" type="text/css">
 9 </head>
10 <body>
11     <div class="div-flex">
12         <!-- 快捷键:.div-flex-item*10 -->
13         <div class="div-flex-item">1</div>
14         <div class="div-flex-item">2</div>
15         <div class="div-flex-item">3</div>
16         <div class="div-flex-item">4</div>
17         <div class="div-flex-item">5</div>
18         <div class="div-flex-item">6</div>
19         <div class="div-flex-item">7</div>
20         <div class="div-flex-item">8</div>
21         <div class="div-flex-item">9</div>
22         <div class="div-flex-item">10</div>
23     </div>
24 </body>
25 </html>

  2.CSS

  1 /* flex是弹性盒子
  2 作用:让我们更好的布局页面中的各个模块的,可以让我们更好的控制块的摆放方式 
  3 优势:可以更方便的实现元素水平居中和竖直居中
  4 水平居中实现方式:
  5 (1)可以把margin设置左右方向设置设置成auto
  6 margin-left:auto;
  7 margin-right:auto;
  8 (2)
  9 display:flex;
 10 justify-content: center;
 11 竖直居中实现方式:
 12 (1)
 13 position:relative
 14 top:50%
 15 transform:translateY(-50%)
 16 (2)
 17 display:flex;
 18 align-items: center;
 19 */
 20 .div-flex {
 21     width: 50%;
 22     height: 500px;
 23     background-color: lightgray;
 24     display: flex;
 25     /* 1.设置flex的方式,只需要在父元素上把display改成flex即可 */
 26 
 27     /* 
 28     2.设置flex的摆放顺序的:
 29     (1)flex-direction
 30     (2)flex-wrap
 31     (3)flex-flow
 32      */
 33 
 34     flex-direction: row-reverse;
 35     /* 
 36     row:按行摆,从左往右摆,不加默认也是row
 37     row-reverse:从右往左摆
 38     column:按列摆,从上往下摆
 39     column-reverse:从下往上摆
 40     把页面变窄,所有的模块会有一个压缩效果
 41     */
 42 
 43 
 44     flex-wrap: wrap;
 45     /* 
 46     wrap是包裹的意思,即换行,定 flex 元素单行显示还是多行显示
 47     默认值为nowrap
 48     */
 49 
 50 
 51     flex-flow: row-reverse wrap;
 52     /* flex-flow 属性是 flex-direction 和 flex-wrap 的结合起来一起写。默认值为:row nowrap*/
 53 
 54 
 55 
 56     /* 
 57     3.设置flex元素对齐方式的:
 58     flex布局有两个轴,行从左往右为弹性容器主轴(或者网格行轴) ,列从上往下为交叉轴(列轴)
 59     这个对齐是跟flex-direction是有关系的,会相互影响
 60     (1)justify-content:主轴对齐方式
 61     列轴上的对齐 
 62     (2)align-items:将所有行在交叉轴上对齐
 63     (3)align-content:与items类似,区别主要有两点
 64     */
 65     justify-content: flex-end;
 66 
 67     /*
 68     flex-start 默认左对齐
 69     flex-end:右对齐
 70     center:每一行居中
 71     space-between:左右两段对齐,每一行左右两端对齐,中间均匀分布
 72     space-around:两端的距离等于中间的一般
 73     space-evenly:两端的距离跟中间一样,即把所有的空隙均匀分布
 74     */
 75 
 76 
 77     align-items: flex-end;
 78     /*
 79     flex-start 默认上对齐,从上往下
 80     flex-end:下对齐
 81     center:每一行居中 
 82     stretch:弹性元素被在侧轴方向被拉伸到与容器相同的高度或宽度
 83      */
 84 
 85 
 86     align-content: flex-end;
 87     /* 
 88     与aligin-items的区别:
 89     ①多行时,行与行之间没有距离
 90     ②单行时,会顶行,竖直不会居中
 91     */
 92 }
 93 
 94 /* 
 95 之前是定义在flex的父元素上,现在定义在每个flex元素的内部
 96 */
 97 
 98 .div-flex-item {
 99     width: 100px;
100     height: 100px;
101 }
102 
103 .div-flex-item:nth-child(odd) {
104     background-color: lightpink;
105     order: 1;
106     /* 定义flex项目的顺序,值越小越靠前 */
107     flex-flow: 3;
108     /* 放大:设置 flex 项主尺寸 的 flex 增长系数 */
109     flex-shrink: 3;
110     /* 缩小 */
111     flex-basis: 10%;
112     /* 设置flex元素的宽度,比初始宽度优先级大 */
113     flex: auto;
114     /* 
115     flex-grow、flow-shrink、flex-basis的缩写。 
116     auto:flex: 1 1 auto
117     none:flex: 0 0 auto
118     */
119 
120 }
121 
122 .div-flex-item:nth-child(even) {
123     background-color: lightgreen;
124     order: 2;
125 
126     flex-grow: 1;
127     flex-shrink: 1;
128 }

 

posted @ 2023-09-20 16:25  R-Bear  阅读(74)  评论(0编辑  收藏  举报