前端之CSS

news2025/1/25 7:00:38

                          

目录

一.CSS是什么

二.CSS的基本语法规范

三.CSS的引入方式

1.内部样式

2.内联样式

3.外部样式

四.CSS的基本用法

1.基础选择器

1.1 标签选择器

1.2 类选择器

 1.3 id选择器

 1.4 通配符选择器

2.复合选择器

2.1 后代选择器

2.2 子选择器

2.3 并集选择器

2.4 伪类选择器

 3.字体属性

3.1字体类型

3.2 字体大小

3.3字体粗细

3.4 字体样式

4.文本属性

 4.1 文本颜色

 4.2 文本对齐

4.3文本装饰 

 4.4 文本缩进

5.行高

垂直方向的水平居中

6.背景属性

6.1 背景颜色

6.2 背景图片

6.3 背景平铺

6.4 背景位置

6.5 背景尺寸

7.圆角矩形 

8.改变显示模式

 9.盒子模型

 9.1 边框

9.2 内边距 

9.3 外边距

9.4 元素的水平居中

10.弹性布局


 前面介绍了HTML的基本语法,接下来就来介绍一下CSS!!!

一.CSS是什么

CSS描述的是页面的样式,也就是描述了一个网页的元素(大小/位置/字体/颜色/背景/边框),引入CSS就是为了让页面变得更加好看,能够实现美化页面的效果,也就是我们经常所见的美颜的效果,让页面更符合人们的审美,因此对于一个普通的程序员而言设置一个好看的页面就有些困难了,因此一般这里会有另一个岗位"美工,设计,UED"来负责设计,这里就不详细介绍了!

二.CSS的基本语法规范

每一个CSS语句包含两个部分:选择器+ 应用的属性,而css代码一般放在style里面

   <style>
        p{ 
             color: blue;      
         } 
    </style>
    <p>hello</p>

例如上面放在style里面的代码就是CSS的基本用法,外面的p就是选择器,这里就表示选择页面中的所有p标签,{}里面的是一个个键值对,就用来表示CSS里面的各种属性,一般习惯每个键值对独占一行用;来分割一行,每个键值对之间用:分割,里面的color是设置颜色的属性,这里就表示设置为蓝色,就会有蓝色的效果出现!!

另外再说一下,我们这里虽然是将每个键值对是分行写的,这是展开风格的CSS代码,但是其实在日常网页里面就会发现其实这些都被放到一行中去(也就是紧凑风格)了:

 因为如果多了一些换行,虽然我们程序员看起来时好看了,但是这个是会让整体的CSS文件变大的,由于CSS文件都是通过网络传输给浏览器的,因此如果CSS文件大了,浏览器解析起来也是更耗费带宽的,速度也就更慢了,因此一般我们写的时候是展开风格,而实际上这个是会通过第三方的工具自动进行替换的(前端的打包工具),这样也是就会让CSS文件变小,然后就可以加快速度了,而且不仅仅CSS是这样的,JS也是这样的,这里就不过多介绍了,了解就好!!

三.CSS的引入方式

1.内部样式

这个内部样式就是和上面的基本语法规范所介绍的代码样式一样,就是放在style里面,然后再嵌套在HTML里面的任意位置,就可以实现CSS的效果了!这样做能够让页面结构和样式分离,但分离的还不够完全,尤其是在CSS内容比较多的时候.

2.内联样式

通过style属性来指定某个标签的样式,只针对当前标签起作用,不对外部的标签其任何作用

   <p style="color: red;">
        hello world
    </p>
    <p>hi</p>

 外面的hi就不会被染成红色,而这样做的坏处就是不能写太复杂的样式,如果过于复杂就会显得特别乱,这个样式一般会搭配JS来使用!

3.外部样式

外部样式就是把css代码单独提取出去,放到一个.css文件然后在html中通过link标签来引入css文件,这样可以让多个html复用同一个样式,link标签一般放在html的head标签里面,而且这个标签可以有多份,通过多个link来引入不同的css样式,也可以实现同样的效果,这是实际开发过程中最常使用的

<head>
    <link rel="stylesheet" href="test.css">
</head>
<body>
    <p>hi</p>
</body>

记得一定要用link标签来调用css文件,这样写样式就和结构彻底分离了!! 

四.CSS的基本用法

1.基础选择器

1.1 标签选择器

对选择的所有标签都会起效,写的选择器就是一个html的标签名例如

   <style>
        p{
            
            color: #000;
        }
    </style>

选中的p就是一个html的标签,这也就是一个标签选择器

1.2 类选择器

类选择器可以选择任何想要的元素,是可以随心所欲的选择的,可以说类选择器包含了所有的选择!!

   <style>
        /* .开头的这个就是CSS中的类名 */
        .red{
            color: red;
        }
    </style> 
    <!-- 通过class属性就可以引入这个CSS类,不需要写.-->
    <p class="red">
        hello Java
    </p>
    <p class="red">
        hello C
    </p>
    <p>
        hello C++
    </p>

通过这个类选择器关联到class属性,就可以选择任何元素了

下面没有选到的也是不会被染到颜色的,因此这个类选择器也是非常的好用的!!

 1.3 id选择器

和类选择器类似,不过这个是使用id属性进行选择的,以#开头,后面带有要选择的id,另外需要给想被选中的元素设置id属性

    <style>
        /* 使用#就可以选中这个id,一个页面的id是唯一的 */
        #one{
            color: rgb(255, 0, 0);
        }
    </style>
    <p id="one">
        hello Java
    </p>
    <p>
        hello C
    </p>
    <p>
        hello C++
    </p>

id在整个页面是唯一的,因此对于id选择器来说每次只能选择一个标签这也是和类选择的区别!

 1.4 通配符选择器

*就是这里的通配符,就直接选中了页面的所有元素,这个最大的用处就是取消掉浏览器的默认样式

    <style>
        *{
            /* 这几个属性就是默认取消掉页面的所有默认样式 */
            margin: 0;
            padding: 0;
            box-sizing: border-box;
        }
    </style>
    <p id="one">
        hello Java
    </p>
    <p>
        hello C
    </p>
    <p>
        hello C++
    </p>

再看一下没有设置这个的样式:

发现差距还是有的,中间的间距是很明显可看出来的,这也是通配符选择器的最大用处(特殊情况下会使用到这个选择器)!!

2.复合选择器

2.1 后代选择器

后代选择器,通过多个选择器的组合,选中某个元素的子/孙元素(后代元素)

<style>
        /* 后代选择器选择ul中的所有后代都设置样式,ul和li中间一定要有空格 */
        ul li{
            color: blue;
        }
         /* 后代选择,中间也要有空格,没有空格的话就是在找ul同时class为san的元素 */
        ul .san{
            color: red;
        }
         /* 孙子后代选择*/
        ul a{
            color: aqua;
        } 
    </style>
    <ul>
        <li class="san">张三</li>
        <li>
            <a href="#">李四</a>
        </li>
        <li>王五</li>
    </ul>
    <ol>
        <li>张三</li>
        <li>李四</li>
        <li>王五</li>
    </ol>

也是有非常明显的效果,子代和孙子都是可以直接设置的,另外一定要注意空格!!!

2.2 子选择器

 子选择器,通过多个选择器的组合,选中某个元素的子元素起效果,子选择器中间会有个>

<style>
        /* 子选择器 */
        ul>.san{
            color: red;
        }
        ul>a{
            color: red;
        }
    </style>
    <ul>
        <li class="san">张三</li>
        <li>
            <a href="#">李四</a>
        </li>
        <li>王五</li>
    </ul>
    <ol>
        <li>张三</li>
        <li>李四</li>
        <li>王五</li>
    </ol>

 这里也就可以看一看出来子类可以选择成功,但是子类的子类a标签就不能选择成功了,这也就是和后代选择器的区别就是后代还可以选孙子,但子选择器不行!!!

2.3 并集选择器

并列多个选择器,可以是后代选择器,也可以是子选择器中间用,隔开

    <style>
        ul .san,
        ol>li{
            color: red;
        }
    </style>
    <ul>
        <li class="san">张三</li>
        <li>李四</li>
        <li>王五</li>
    </ul>
    <ol>
        <li>张三</li>
        <li>李四</li>
        <li>王五</li>
    </ol>

任何的基础选择器都可以使用并集选择器来表示,并集选择器减一竖着写,每个选择占一行

2.4 伪类选择器

这里主要介绍两个:hover鼠标悬停的时候,应用这个样式,:active鼠标按下的时候,应用这个样式

    <style>
        /*原本的样式*/
        div{
            color: #000;
        }
        /* 鼠标悬停的时候,应用这个样式  */
        div:hover{
            color: blue;
        }
        /* 鼠标按下的时候,应用这个样式 */
        div:active{
            color: red;
        }
    </style>
    <div>一个div</div>

当鼠标停留在这上面的时候:当鼠标点击的时候: 松开后又会恢复,这确实还是一个比较有意思的样式!!!

首先CSS中的属性是非常非常多的,因此这里我只介绍一些常见的,如果遇见没有见过的属性,建议可以参考CSS参考文档边查边用!!! 

 3.字体属性

3.1字体类型

 这里的字体类型一定要在机器上有这种字体,没有的话可能是加载不出来的,最好的方法是通过html中的link属性自己加载基本都可以加载出来

     <style>
        /* font-family 字体 */
       
        .one{

            font-family: "微软雅黑";
        }
        .two{
            font-family: "幼圆";
        }
    </style>
    <div class="one">
        这是一段字
    </div>
    <div class="two">
        这是另一段字
    </div>

font-family就是字体类型的属性

这样就可以设置不用的字体样式 

3.2 字体大小

font-size就是设置字体大小的属性,这里记得一定要加单位px(像素)

    <style>
        /* font-size 大小 加px像素*/
        .one{
            font-size: 10px;
        }
        .two{
            font-size: 30px;
           
        }
    </style>
    <div class="one">
        这是一段字
    </div>
    <div class="two">
        这是另一段字
    </div>

这个的区别还是十分明显的,另外这个的大小也可以通过单词来设置例如small,large,normal都是可以的!! 

3.3字体粗细

font-weight字体粗细,可以用数字来设置,数字越大表示字体越粗(最大900,最小100)

       <style>
        /* font-weight字体粗细 normal是正常,bold粗体 lighter细*/
        .one{
            font-weight: lighter;
        }
        .two{
            font-weight:900;
        }
    </style>
    <div class="one">
        这是一段字
    </div>
    <div class="two">
        这是另一段字
    </div>

而且这里的字体粗细也是可以通过单词来设置的(normal是正常,bold粗体 lighter细)

3.4 字体样式

font-style可以设置字体样式

 <style>
       
        /* font-style字体样式 italic斜体*/

        .one{
            font-style: italic;
        }
        .two{
            font-style: normal;
        }
    </style>
    <div class="one">
        这是一段字
    </div>
    <div class="two">
        这是另一段字
    </div>

其实一般不怎么会将字体倾斜,更多的是把斜体还原回去,例如em/i这些显示出来都是斜体的,一般通过这个属性就可以将他们改回去的!! 

4.文本属性

 4.1 文本颜色

 ● 直接使用单词(样式比较少,因此很少使用)

   <style>
        /* 
           文本颜色 使用单词
        */
        
        .hh{
            color: blue;
        }
    </style>
    <div class="hh">
        这是一段话
    </div>

 ● 使用rgb(红色,绿色,蓝色)  (机器上的色光三原色,通过这些不同的颜色混合就可以搭配出不同的颜色,在CSS里面给这三个分量分别使用一个字节来表示0~255,这个常用)

    <style>
        .hh{
            color: rgb(255, 0, 0);
        }
    </style>
    <div class="hh">
        这是一段话
    </div>

 ● 使用16进制的rgb (这里不区分大小写FF和ff是一样的,而且这里是可以缩写的例如#XXYYZZ就可以缩写为#XYZ(必须三个组合都满足才能缩写))

    <style>
        .hh{
            color: #088;
        }
    </style>
    <div class="hh">
        这是一段话
    </div>

 ● 使用rgba(红色,绿色,蓝色,透明度)  (多了个分量alpha表示透明度,取值为0~1(0是最透明的,1是没有透明度的))

    <style>
        .hh{
            color: rgba(255, 0, 0, 0.3); 
        }
    </style>
    <div class="hh">
        这是一段话
    </div>

 4.2 文本对齐

text-align可以设置这个样式,lef靠左对齐,center居中,right靠右对齐(这个在前面写html表格的时候就使用到了!)

    <style>
        .one{
            text-align: left;
        }
        .two{
            text-align: center;
        }
        .three{
            text-align: right;
        }
    </style>
    <div class="one">
        这是一段字
    </div>
    <div class="two">
        这是另一段字
    </div>
    <div class="three">
        这是又一段字
    </div>

4.3文本装饰 

通过这个text-decoration属性,可以实现下划线,删除线...(这里最主要的还是去掉下划线)

    <style>
        a{
            text-decoration: none;
        }
        div{
            text-decoration: line-through;
        }
    </style>
    <a href="#">
        空链接
    </a>
    <div>
        这是一段话
    </div>

可以看到a标签下面的下划线已经被删除掉了,这里在开发者工具里面也是可以手动选择起效

 4.4 文本缩进

文本缩进:text-indent,默认的文本段落是不会缩进的,因此需要使用这个样式才可以

    <style>
        div{
            text-indent: 2em;
        }
    </style>
    <div>
        一段话:Lorem ipsum dolor sit amet consectetur adipisicing elit. Velit quo unde corrupti nobis pariatur accusamus facilis consequatur nesciunt sint dignissimos, veniam dolorem eos hic molestiae fugit quia sequi reiciendis ex!
        Lorem ipsum dolor sit, amet consectetur adipisicing elit. Reprehenderit optio pariatur, eos porro perspiciatis impedit itaque voluptatem sit amet consequatur corrupti, iste ut voluptate quasi officia nisi, voluptates est quisquam.
    </div>

这里的单位可以使用数字+px,但是一般会使用另一个单位em(表示当前元素的文字大小),这个单位是非常必要的,因为有些页面是可以放大缩小字体的,不能因为放大或缩小了字体而导致页面排版出现问题,因此就得使用em单位来确认当前页面的字体大小来保证缩进,另外这个缩进的单位可以是负数的,表示反向缩进!

 

5.行高

line-height:行高=字体大小 + 行间距,对于一个文本而言有四条线,最顶部的称为顶线,最底部的称为底线 最中间的称为中线,而在底线和中线中间还有一条基线(这是英文字母中四线格中的第三条线)而一个行高就是两个文本顶线到顶线的距离,底线到底线的距离,中线到中线的距离,基线到基线的距离

    <style>
        /* 设置行高 */
        .two{
            line-height: 50px;
        }
    </style>
    <div class="one">
        上一行
    </div>    
    <div class="two">
        中间行
    </div>
    <div class="three">
        下一行
    </div>

  对比一下没有设置行高:

 可以看到设置行高时会同时对上下两个方向都会产生影响,上下领个边距都是均等的!!!

垂直方向的水平居中

又因为行高是上下均等的,因此就可以基于行高来设置文本的垂直方向居中

    <style>
        div{
            /* 设置元素的行和列  另外再设置个背景颜色(后面会介绍到这里先用一下) text-align是水平居中,line-height就是行高了(将两个都设置为居中就可以实现正中心了) */
            width: 200px;
            height: 150px;
            font-size: 20px;
            background-color: bisque;

            text-align: center;
            line-height: 150px;
        }
    </style>
    <div>
        一个div
    </div>

 

 就可以结合水平居中和垂直居中实现文本出现在元素正中心的位置上了!

这里的一个小细节:元素高度是多少就设置多高的行高就可以垂直方向居中了!!

 

6.背景属性

6.1 背景颜色

背景颜色background-color,和前面设置颜色的方法都是一样的,这就不再介绍了,background-color设置背景颜色,color设置文字颜色(尽量设置的不要太接近,不然会看不清楚)

    <style>
        div{
            width: 500px;
            height: 360px;
            font-size: 20px;
            background-color: bisque;
            color: #000;
        }
    </style>
    <div>
        一个div
    </div>

                           

另外还可以设置一个transparent就是继承父类的颜色,在不设置背景颜色的情况下,就会默认使用这个颜色继承body的颜色!!

6.2 背景图片

使用background-image这个属性来设置背景图片,url里面包含图片的地址

<style>
        div{
            width: 500px;
            height: 360px;
            font-size: 20px;
            background-color: bisque;
            color: #000;
            text-align: center;
            line-height: 360px;
            /* 设置背景图片 */
            background-image: url(b.jpg);
            
        }
    </style>
    <div>
        一个div
    </div>

 背景图片是默认平铺在元素内的!

6.3 背景平铺

上面的图片默认就是平铺在元素中的,那么想不让图片平铺就得使用得使用属性background-repeat来设置为图片平铺,no-repeat就是不平铺,repeat就是默认选项 repeat-x水平平铺 repeat-y垂直平铺,这里就测试一下不平铺:

    <style>
        div{
            width: 500px;
            height: 360px;
            font-size: 20px;
            background-color: bisque;
            color: #000;
            /* 设置背景图片 */

            background-image: url(b.jpg);
            /* 图片默认是平铺的,background-repeat就可以设置为图片平铺,no-repeat就是不平铺,repeat就是默认选项 repeat-x水平平铺 repeat-y垂直平铺 */
            
            background-repeat: no-repeat;
            text-align: center;
            line-height: 360px;
        }
    </style>
    <div>
        一个div
    </div>

 可以发现背景图片是覆盖背景的,因此设置的背景图片会盖住其位置的背景颜色,而文本又是在背景图片上面的,不会被覆盖!

6.4 背景位置

想改变背景图片的位置,就需要background-position来设置,使用数字+px来设置也是可以的,但是如果想居中的话就需要自己计算,因此想设置到中间的话可以使用百分比或者单词的形式来设置

<style>
        div{
            width: 500px;
            height: 360px;
            font-size: 20px;
            background-color: bisque;
            color: #000;

            /* 设置背景图片 */
            background-image: url(b.jpg);
            
            background-repeat: no-repeat;
            
           
            /* 坐标位置 */
            background-position: 50% 50%;
            /* background-position: center center; */

            text-align: center;
            line-height: 360px;
        }
    </style>
    <div>
        一个div
    </div>

 可以发现图片已经放到了正中间!

6.5 背景尺寸

又发现上面的背景图片的大小是远小于元素的大小的,因此使用background-size属性来设置 背景大小,可以使用数字加px直接设置,另外也可以直接使用英文单词来设置(contain(把图片拉伸到元素大小就结束了,保证背景图始终在元素内) 和 cover(会把元素全部覆盖)都是自适应的)

   <style>
        div{
            width: 500px;
            height: 360px;
            font-size: 20px;
            background-color: bisque;
            color: #000;
            /* 设置背景图片 */

            background-image: url(b.jpg);
            
            background-repeat: no-repeat;
         
            background-position: 50% 50%;
            
          
            background-size: contain; 


            text-align: center;
            line-height: 360px;
        }
    </style>
    <div>
        一个div
    </div>

  总结一下:background这一系列属性对于图片的处理能力是要强于image的处理能力的,因此在实际开发中background会更常用一些!!!

7.圆角矩形 

HTML里面的元素都是默认矩形的,而想要设置的圆滑一些更好看一些就要通过border-radius来设置其圆角:

     <style>
        /* 这里border-radius的取值更像是这个矩形的切圆的半径一样,半径越大,就会越圆一些 */
        div{
            width: 400px;
            height: 200px;
            background-color: bisque;
            color: black;
            
            border-radius: 50px;
            line-height: 200px;
            text-align: center;
        }

    </style>
    <div>
        一个div
    </div>

 通过手动调节这个也可以的

而通过这个就可以设置成一个圆形(将这个设置为宽度的一半就可以了),而且要是不想写数字的,还是可以写百分比的

    <style>
        div{
            width: 200px;
            height: 200px;
            background-color: bisque;
            color: black;
            
            border-radius: 100px;
            line-height: 200px;
            text-align: center;
        }

    </style>
    <div>
        一个div
    </div>

另外这也可以分开四个角来写,分别设置四个角:

     <style>
        div{
            width: 400px;
            height: 200px;
            background-color: bisque;
            color: black;
            
            line-height: 200px;
            text-align: center;
            /*可以分开四个角分别写 */
            border-top-left-radius: 50%;
            border-top-right-radius: 50%;
            border-bottom-left-radius: 50%;
            border-bottom-right-radius: 50%; 
            /* 也可以按照四个角的顺序依次写在border-radius里面 */

        }

    </style>
    <div>
        一个div
    </div>

 这个就不过多介绍了!!

 

8.改变显示模式

块级元素(div,p,h1-h6),行内元素(a,span不能设置宽和高),行内块元素(input,img不独占一行,但是能设置宽和高),而块级元素都是独占一行的,有时候斯需要将几个块级元素放在一行的,该怎么做呢?  通过display可以把行内元素设置块级元素,块级元素设置为行内元素

   <style>
        a{
            width: 60px;
            height: 100px;
            display: block;          
        }
    </style>
    <a href="#">空链接1</a>
    <a href="#">空链接2</a>
    <a href="#">空链接3</a>

   可以发现行内元素已经变成块级元素了

另外display还有一个特殊的选项设置为none就可以让选中的元素隐藏起来,这个就不演示了,感兴趣的可以自己去设置一下!!

 9.盒子模型

HTML的元素其实是由这几个部分构成的 margin外边距(就像是房子和其他房子的距离) border边框(相当于房子的外墙) padding内边距(相当于家中的东西距离墙的距离),然后最里面的就是具体的内容了

 9.1 边框

    <style>
        div{
            width: 200px;
            height: 200px;
            background-color:bisque;
            /* 2px大小的边框,颜色为黑色,且是实心的(边框样式也是有很多种的,border-style可以查到) */
            border: 2px black solid;
            
        }
    </style>
    <div class="one">
        一个div
    </div>    
   

                     

 而通过开发者工具查看发现设置一个边框是会撑大原有元素的尺寸的,这个就有可能会出现问题的(有可能就导致元素尺寸改变,进一步就影响到页面布局了),因此在实际的开发过程是将box-sizing设置为border-box此时的设置的边框就会挤压内容而不会撑大元素!!

    <style>
        div{
            width: 200px;
            height: 200px;
            background-color:bisque;
            /* 2px大小的边框,颜色为黑色,且是实心的(边框样式也是有很多种的,border-style可以查到) */
            border: 2px black solid;
            box-sizing: border-box;

        }
    </style>
    <div class="one">
        一个div
    </div>    
   

 此时就是挤压自己元素的大小了而不是用外面的空间了

9.2 内边距 

 里面的内容和边框的距离通过padding来设置

    <style>
        div{
            width: 200px;
            height: 200px;
            background-color:bisque;
            /* 2px大小的边框,颜色为黑色,且是实心的(边框样式也是有很多种的,border-style可以查到) */
            border: 2px black solid;
            box-sizing: border-box;
            padding: 20px;

        }
    </style>
    <div class="one">
        一个div
    </div>    
   

就会发现里面的内容距离边框就会远了,这里设置的比较大,是为了效果更明显!

9.3 外边距

 通过margin属性来设置

    <style>
        div{
            width: 200px;
            height: 200px;
            background-color:bisque;
          
            border: 2px black solid;
            box-sizing: border-box;
            padding: 20px;
        }
        .one{
            margin-bottom: 10px;
        } 
        .two{
            margin-top: 20px;
        }
    </style>
    <div class="one">
        一个div
    </div>    
    <div class="two">
        一个div
    </div>

使用开发者工具查看发现外边距并不是两个外边距相加起来的,而是重叠了,这里就需要注意外边距在垂直方向是会存在"塌陷"的情况的,两者都设置了外边距,这里的外边距是不会累加的,而是会重叠,取其最大值,但是在(内边距)水平方向是会相加的!!

9.4 元素的水平居中

这里基于margin还可以实现元素的水平居中(不是文本)

      <style>
         .one{
             width: 400px;
             height: 200px;
             background-color:bisque;
         }
         .two{
             height: 50px;
             width: 100px;
             background-color: aquamarine;
             /* 想要让这个块级元素处在中间位置 0表示上下外边距为0,auto表示左右外边距自适应(水平居中)*/
             margin: 0 auto;
         }
     </style>
     <div class="one">
        <div class="two">
            hello
        </div>
    </div>    

 就可以让这个块内元素水平居中了,但是垂直方向上的通过margin设置还是不行的,这个就不介绍了!!

10.弹性布局

弹性布局主要是安排页面上的元素的位置(排列方式) ,实际上盒子模型的外边距就影响到了元素和元素之间的布局,但这还不够,弹性布局就是强化这一点的,默认的网页布局是从上到下的,而实际的网页则是既有从上到下,还有从左到右,因此就得使用到弹性布局

    <style>
        .parent{
            /* width: 100%表示继承body的宽度  */
            width: 100%;
            height: 200px;
            background-color: bisque;
            
            /* div是独占一行的,而想要让子元素的div在父元素中水平排列就得用到弹性布局 给父元素设置一个属性 display: flex,就可以了 */
            display: flex;
        
        }
        .one{
            width: 100px;
            height: 100px;
            background-color: aquamarine;
        }
    </style>
    <div class="parent">
        <div class="one">1</div>
        <div class="one">2</div>
        <div class="one">3</div>
        <div class="one">4</div>

    </div>

->

 可以看出来使用了弹性布局之后块级元素也可以水平放置了!

默认这些元素的排列方式是在左上角的,而想要改变排列方式就得使用另一个属性,水平方向:justify-content,start表示靠左排列,end表示靠右排列,center表示居中排列 space-between表示让元素之间有均匀的间隔 space-around表示除中间外左右也有间隔

    <style>
        .parent{
            /* width: 100%表示继承body的宽度  */
            width: 100%;
            height: 200px;
            background-color: bisque;
            
            /* div是独占一行的,而想要让子元素的div在父元素中水平排列就得用到弹性布局 给父元素设置一个属性 display: flex,就可以了 */
            display: flex;
            justify-content: space-around;
        }
        .one{
            width: 100px;
            height: 100px;
            background-color: aquamarine;
        }
    </style>
    <div class="parent">
        <div class="one">1</div>
        <div class="one">2</div>
        <div class="one">3</div>
        <div class="one">4</div>

    </div>

 

 可以发现效果还是很明显的!!

另外垂直方向也是和水平方向一样的,属性是align-items就直接使用了

     <style>
        .parent{

            width: 100%;
            height: 200px;
            background-color: bisque;
          
            display: flex;
           
            justify-content: space-around;
            
            /* 垂直方向也是一样的设置方式  最常用的还是放在中间*/
            align-items: center;
        }
        .one{
            width: 100px;
            height: 100px;
            background-color: aquamarine;
        }
    </style>
    <div class="parent">
        <div class="one">1</div>
        <div class="one">2</div>
        <div class="one">3</div>
        <div class="one">4</div>

    </div>

 就可以将其元素放在中间了,弹性布局也是十分好用的!!!

 好了介绍到这里基本的CSS样式就介绍的差不多了,这里的样式还是很多的,不过这里的样式也只是一些常用的,还有很多样式是没有介绍到的,因此想要使用的话可以在CSS参考文档里面查找使用!!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/407818.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

【实战篇】最详细的Rollup打包项目教程

介绍 本文带你一起使用 Rollup 打包项目&#xff0c;实现以下功能&#xff1a; 自动将 dependencies 依赖声明为 externals支持处理外部 npm 依赖支持基于 CommonJS 模块引入支持 typescript&#xff0c;并导出声明文件支持 scss&#xff0c;并添加前缀支持自动清除调试代码打…

怒肝最新保姆级前端学习路线,速成贴心全面!

这份学习路线并不完美&#xff0c;也不会有最终形态&#xff0c;正如前端不可预见、永无止境的未来。 大家好&#xff0c;我是鱼皮&#xff0c;肝了几天终于完成了这份保姆级前端学习路线。 &#x1f482; &#x1f4bb; &#x1f474;&#x1f3fd; 先放一张图&#xff1a…

JS原型与原型链详细解释

文章目录一、JS原型链简要解释二、JS原型链详细解释1.构造函数2.原型对象3.__proto__4.原型链总结一、JS原型链简要解释 原型是function对象上的一个属性, 它表示构造函数构造出来的对象的共有祖先, 被通过构造函数构造出来的对象上有一个__proto__属性指向该函数的prototype,…

JSON.parse和JSON.stringify的用法

平时我们在接收后端返回的json对象通常是一个字符串类型的object&#xff0c;所以一般我们要对这个object进行类型转化后&#xff0c;我们才能使用object里面的数据&#xff0c;而这其中涉及到两个必不可少的方法就是JSON.parse和JSON.stringify JSON.parse()JSON.parse()方法将…

vue 控制元素的显示和隐藏

方法&#xff1a; 使用 v-if 指令&#xff0c;通过动态的向DOM树内添加或者删除DOM元素的方式来显示或隐藏元素&#xff1b;使用 v-show 指令&#xff0c;通过设置DOM元素的display样式属性来控制显隐。v-if 指令与 v-show 指令都可以根据值动态控制DOM元素显示隐藏&#xff0…

文档库开发之-vite打包优化

背景 首次进行组件库文档打包&#xff0c;遇到了一些ts打包报错和css打包警告&#xff0c;记录下处理过程。并且发现打包后的主包的体积过大&#xff0c;有一定优化空间 ts报错处理 当时有好奇为什么开发环境下都不报错&#xff0c;构建才产生这么多ts错误。大致猜想可能vite…

英雄联盟轮播图自动轮播

六月过去了&#xff0c;七月还会远吗&#xff1f;不知不觉到了六月底的最后一天。你好&#xff0c;七月&#xff01; 大家好&#xff0c;我是小陈陈呀&#xff0c;上次写了一篇英雄联盟轮播图手动轮播&#xff0c;当天晚上有很多大朋友小朋友私信小陈陈&#xff1a;可以在上次…

【微信小程序】一文读懂页面导航

&#x1f381;写在前面&#xff1a; 观众老爷们好呀&#xff0c;这里是前端小刘不怕牛牛频道&#xff0c;小程序系列又更新了呀&#xff0c;今天的内容是微信小程序的页面导航&#xff0c;非常重要&#xff0c;赶紧拿起小本本记起来呀&#xff01; 文章目录一&#xff0c;页面导…

【项目问题定位】前端请求不到资源报错ERR_CONTENT_LENGTH_MISMATCH的解决

文章目录问题简述问题背景问题定位初始报错定位好像是网络问题ERR_CONTENT_LENGTH_MISMATCH 200 是什么原因&#xff1f;原来是Nginx报错了为何没有权限&#xff1f;nobody的原因问题解决原因总结知识点问题简述 前端页面加载资源时&#xff0c;出现ERR_CONTENT_LENGTH_MISMAT…

前端异常:“Uncaught SyntaxError: missing ) after argument list“真的只是参数列表后面缺少 “)”?

案发现场 我们在写JS的时候&#xff0c;有时候报错"Uncaught SyntaxError: missing ) after argument list"&#xff0c;字面翻译过来的意思&#xff1a;语法错误: 参数列表后面缺少 )。 这真的就是缺少括号的意思吗&#xff1f;然而只是真的缺少括号才会出现这样的…

HTML的常见标签及用法

一、注释标签 形如&#xff1a;<!-- -->的格式就叫做注释标签&#xff0c;在代码中起到解释说明的作用。 二、标题标签 在HTML中有六种格式的标题标签类型&#xff0c;分别是h1,h2,h3,h4,h5,h6。对应的形式为&#xff1a; 三、段落标签 当文章需要分段时&#xff0c;使…

js除法取整(js除法向上取整)

Javascript取整问题。要求只要有小数存在就进一位。例如&#xff1a;2.1取3&#xff0c;3.1取4 var a 2.0; function parseNumber(number, splitChar) { var n number ; var s splitChar nullvar a 2.1; var b parseInt(a) 1; // b will be 3 parseInt是截掉尾数&#…

vxe-table表格合并单元格和编辑

//这是在vue上面引用vxe-table插件实现的&#xff0c;主要方法都设置在table中&#xff0c;mergeCells&#xff0c;tableData都是在vue页面的data初使化数据&#xff0c; :footer-method“footerMethod”&#xff1a;尾部数据&#xff0c;:merge-footer-items“mergeCells”&am…

vue通过url方式展示PDF方法总结

最近vue项目中遇到预览pdf出现乱码问题&#xff0c;尝试了各种办法受尽折磨&#xff0c;以此记录一下使用的几种方法 1.使用pdfjs-dist 插件&#xff0c;通过iframe标签显示 首先 npm install pdfjs-dist --save npm直接下载插件 npm install --save pdfjs-dist2.0.943&…

【vue 项目】有关cascader任选一级、字段名不同、同时获取value和label值、回显(推父节点)等问题解决

文章目录选择任意一级选项字段名转换最后一级数据为空显示暂无数据问题同时获取cascader的value和label值选择时双击两次才显示被选中&#xff08;单选选择任意一级组件&#xff09;Error in callback for watcher “options“: “TypeError: Cannot read property ‘level‘ o…

表单元素盘点第二弹<form><textarea>元素详细介绍

博主有话说&#xff1a;如果有描述错误之处请大家纠正。让我们可以一起学习一起进步。 个人主页&#xff1a;GUIDM主页 内容专栏&#xff1a;干货 此块内容为纯纯的干货&#xff0c;略显乏味枯燥&#xff0c;是笔记向的blog。如果觉得还不错&#xff0c;希望你可以一键三连&…

Vue2的响应式原理

--------Vue2响应式原理---------- 原理&#xff1a;通过数据劫持 defineProperty 发布订阅者模式&#xff0c;当 vue 实例初始化后 observer 会针对实例中的 data 中的每一个属性进行劫持并通过 defineProperty() 设置值后在 get() 中向发布者添加该属性的订阅者&#xff0c…

基于RuoYi若依vue的数据分页功能的前后端代码详解

目录 1.前端代码 1.1首先在前端会有一个 组件&#xff0c;为分页组件 1.2前端获取列表函数以及访问后端的URL与请求方式 1.3开发者工具查看前端访问后端信息 1.4开发者工具查看前端接收到后端的回应信息 2.后端代码 2.1接口 2.2接口内方法的代码 2.3后端Log输出如下 1.前…

IntersectionObserver API详解

过去&#xff0c;要检测一个元素是否可见或者两个元素是否相交并不容易&#xff0c;比如实现图片懒加载、内容无限滚动等功能时&#xff0c;都需要通过​getBoundingClientRect()​写大量的逻辑计算或者依靠scroll事件监听等性能很差方式来实现。 现在&#xff0c;依靠Interse…

Object.prototype.toString.call()的原理

今天在项目中看到了用Object.prototype.toString.call()这个方法封装的检测数据类型的工具。 但是浏览器搜索相关原理的好回答凤毛麟角&#xff0c;故而想记录一下&#xff0c;万一可以帮助到更多的新手呢&#xff1f;我的文章都是非常通俗易懂的&#xff0c;因为我写文章的时…