首页 > 其他分享 >学习HTMLCSS第六天

学习HTMLCSS第六天

时间:2024-09-23 15:24:17浏览次数:13  
标签:设置 color 元素 height 学习 第六天 background HTMLCSS left

CSS 核心属性详解

在前端开发中,CSS(层叠样式表)起着至关重要的作用,它可以让网页变得更加美观和易用。本文将详细介绍 CSS 中的一些核心属性,包括行高、圆角、透明度、颜色值、浮动、定位和子绝父相等。

一、行高(line-height)

  1. 概念:行高是指文本行与行之间的间距,实际上是每行文本基线与基线之间的间距。
  2. 属性值:可以设置为倍数或像素值。
    • 例如:line-height: 1.75表示行高为字体大小的 1.75 倍;line-height: 200px表示行高为 200 像素。
  3. 单行文本垂直居中:对于单行文本,可以设置行高等于标签的高度来实现垂直居中。
  4. 多行文本垂直居中:对于多行文本,可以通过设置内边距来实现垂直居中,如padding-top: 80px; padding-bottom: 80px;
<!-- 
  line-height
  行高: 文本行与行之间的间距。
  其实是指每行文本基线与基线之间的间距

-->
<style>
    .text {
        background-color: red;
        font-size: 40px;
        /* 属性值: 倍数 / px */
        line-height: 1.75;
    }
</style>

<div class="text">
    xfgj  hello world
</div>

<style>
 .box {
    font-size: 40px;
    background-color: green;
    height: 200px;
    /* 1)遇到一行文本(单行文本)垂直居中,可以设置行高等于标签的高度 */
    line-height: 200px;
 }
</style>
<div class="box">
  xfgj  hello world
</div>

<style>
    .demo {
        background-color: blue;
        font-size: 40px;
        /* 2)遇到多行文本垂直居中,可以通过内边距居中 */
        padding-top: 80px;
        padding-bottom: 80px;
    }
</style>
<div class="demo">
    xfgj  hello world <br>
    xfgj  hello world <br>
    xfgj  hello world <br>
    xfgj  hello world 
</div>

 

二、圆角(border-radius)

  1. 作用:用于设置元素的圆角。
  2. 早期低版本浏览器不支持圆角的解决方案:采用图片代替。
  3. 属性设置
    • 可以设置一个统一的圆角半径,如border-radius: 100px;将元素设置为圆形。
    • 也可以分别设置不同的圆角,如border-top-left-radius: 40px; border-top-right-radius: 40px; border-bottom-left-radius: 10px; border-bottom-right-radius: 10px;
<!-- 圆角,早期低版本浏览器,不支持圆角怎么办?答案:采用图片代替。 -->
 <style>
    .box {
        width: 200px;
        height: 200px;
        background-color: blue;
        /* 圆角属性 */
        border-radius: 100px;
    }
 </style>
<div class="box"></div>

<style>
    .demo {
        width: 200px;
        height: 300px;
        background-color: green;
        /* 分别设置不同的圆角 */
        border-top-left-radius: 40px;
        border-top-right-radius: 40px;
        border-bottom-left-radius: 10px;
        border-bottom-right-radius: 10px;
    }
</style>
<div class="demo"></div>

三、透明度(opacity)

  1. 作用:设置标签的透明度。
  2. 注意事项:当设置标签透明时,标签和文本都会变透明,且完全透明时(opacity: 0;),标签虽然看不见,但仍然占位置。例如:opacity:.5;表示透明度为 50%。

<style>
    .box-2 {
        width: 300px;
        height: 100px;
        font-size: 40px;
        background-color: rgb(0,0,255);
        /* 设置标签透明
           标签和文本都变透明了
           opacity: 0; 完全透明,但标签不是消失,还是占位置的。
         */
        opacity: .5;
    }
</style>
<div class="box-2">
    hello abc
</div>

四、颜色值

  1. 设置方式
    • 英文词汇,如white(白色)、black(黑色)、red(红色)等。
    • 十六进制,如#ffffff(白色)、#000000(黑色)。十六进制由数字 0-9 和字母 a-f 组成。
    • rgb()函数,如rgb(0,255,255)表示青色。
    • rgba()函数,如rgba(255,255,255,.5),最后一个参数表示透明度。
    • hsl()函数,如hsl(色调,饱和度,亮度)
<style>
    .box {
        width: 100px;
        height: 100px;
        /* 1) 英文词汇 white black  red green blue pink purple orange gray yellow lightgreen .... */
        /* 2)  十六进制 #ffffff  #000000  (0,1,2,3,4,5,6,7,8,9,a,b,c,d,e,f) */
        /* 3)  rgb(0,255,255) 或者 rgba(255,255,255,.5)  */
        /* 4)  hsl(色调,饱和度,亮度) */
        background-color: #d70a0a;
    }
</style>
<div class="box"></div>

五、浮动(float)

  1. 作用:设置元素靠左或者靠右摆放,使元素脱离正常文档流。
  2. 属性值float: left;表示左浮动,float: right;表示右浮动。
  3. 影响:浮动的元素不占位置,会影响后面的 HTML 标签,但不会影响前面的 HTML 标签。
  4. 清除浮动
    • 可以在受浮动影响的元素后面添加一个块元素,并设置clear: both;属性来清除浮动的影响。
    • 也可以使用伪类元素清除浮动,如给父元素添加clearfix类名,在 CSS 中设置.clearfix::after { content: ""; display: block; clear: both; }
 <!-- 
     浏览器在解析html文档时,正常的顺序是从上往下、从左往右解析。
     这个正常的解析过程,我们叫做正常文档流(标准文档流)    
    -->


<style>
    /* 浮动: 设置元素靠左或者靠右摆放。 */
    .fl {
        float: left;
    }
    .fr {
        float: right;
    }
</style>
<!-- 
  123 
-->
<div class="fl">1</div>
<div class="fl">2</div>
<div class="fl">3</div>


<!-- 
   654
-->
<div class="fr">4</div>
<div class="fr">5</div>
<div class="fr">6</div>


 <!-- 
浮动会让元素脱离正常文档流,这个浮动了的标签就不占位置了,
会影响后面的html标签,不会影响前面html标签。
后面的html标签不想受到浮动的影响,可以设置 clear: both; 属性清除浮动的影响。

-->

 <style>
 .clear {
    /* 清除浮动属性 */
    clear: both;
}

/* 使用伪类元素清除浮动 */
.clearfix::after {
    /* 生成伪类元素属于行内元素 */
    content: "";
    /* 把行内元素转成块元素 */
    display: block;
    /* 清除浮动 */
    clear: both;
}

 </style>
    
 <div class="parent">
    <div class="child bg-red"></div>
    <div class="child bg-green"></div>
    <!-- 这个块元素用于清除浮动,那能不能用伪类元素代替这个块元素做清除浮动的事情。 -->
    <div class="clear"></div>
</div>

<!-- 
设置了浮动的元素,不占位置,就无法撑开父元素的高度,就看不见灰色的背景。
在浮动的元素后面添加一个块元素,给这个块元素设置清除浮动即可。

使用这个类名:clearfix 
目的是为了生成伪类标签代替 “<div class="clear"></div>”。

以后遇到哪个标签设置了浮动,就找到这个标签的父元素,给这个父元素设置clearfix类名即可。
就起到清除浮动的作用。
-->

<div class="parent clearfix">
     <div class="child bg-pink"></div>
     <div class="child bg-orange"></div>
</div>

六、定位(position)

  1. 属性值
    • relative(相对定位):不会让元素脱离正常文档流。
    • absolute(绝对定位):会让元素脱离正常文档流,不占位置。
    • fixed(固定定位):会让元素脱离正常文档流,不占位置。
    • sticky(粘性定位):不会让元素脱离正常文档流。
    • static(静态,无定位作用)。
  2. 方位属性:配合left(左)、top(上)、right(右)、bottom(下)等属性使用。同时设置leftright时优先读取left属性值。
  3. 层级属性:可以使用z-index属性设置元素的层级。
 <!-- 
    定位: 设置标签的位置
    position属性
    配合以下属性使用
    方位: left  top  right bottom 
    层级: z-index
    同时设置left和right优先读取left属性值。


    position 有哪些属性值
    relative   相对定位
    absolute   绝对定位
    fixed      固定定位
    sticky     粘性定位(吸顶/吸底)
    static     静态(无定位作用)
    -->

<style>
body {
    margin: 0;
    height: 2000px;
}
.box {
    width: 100px;
    height: 100px;
    font-size: 25px;
}

.box-1 {
    background-color: red;
    /* 相对定位 (不会让元素脱离正常文档流)*/
    position: relative;
    left: 150px;
    top: 0px;
}
.box-2 {
    background-color: green;
    /* 绝对定位 (会让元素脱离正常文档流、不占位置) */
    position: absolute;
    left: 150px;

}
.box-3 {
    background-color: blue;
    /* 固定定位 (会让元素脱离正常文档流、不占位置)*/
    position: fixed;
    left: 300px;
}
.box-4 {
    background-color: orange;
    /* 粘性定位 (不会让元素脱离正常文档流)*/
    position: sticky;
    left: 450px;
    top: 0;
}
.box-5 {
    background-color: purple;
    /* static (没有定位作用的) */
    position: static;
    left: 450px;
    top: 0;
}
.box-6 {
    background-color: pink;
}
</style>
<div class="box box-1">1(相对)</div>
<div class="box box-2">2(绝对)</div>
<div class="box box-3">3(固定)</div>
<div class="box box-4">4(粘性)</div>
<div class="box box-5">5</div>
<div class="box box-6">6</div>

七、子绝父相

  1. 概念:子元素设置为绝对定位,父元素设置为相对定位。
  2. 作用:绝对定位会让元素脱离正常文档流,不占位置;相对定位不会让元素脱离正常文档流,占位置。这样可以方便地对子元素进行定位,同时不影响父元素在文档流中的位置。实在实际的前端开发中,合理运用这些 CSS 属性可以实现各种复杂的布局和效果。通过对行高的调整可以优化文本的排版;圆角可以使元素更加美观;透明度可以实现一些特殊的视觉效果;颜色值的灵活设置可以满足不同的设计需求;浮动和定位则可以实现元素的灵活布局。而子绝父相的技巧更是在一些特定场景下非常有用。
 <!-- 
     子绝父相:
        子元素设置为绝对定位
        父元素设置为相对定位
    
        绝对定位会让元素脱离正常文档流,不占位置,
        相对定位不会让元素脱离正常文档流,占位置
    -->

    <style>
        body {
            margin: 0;
        }
        .header {
            width: 600px;
            height: 80px;
            background-color: darkred;
            margin: 0 auto;
        }
        .main {
            width: 600px;
            height: 600px;
            background-color: deepskyblue;
            margin: 0 auto;
        }
        .footer {
            width: 600px;
            height: 300px;
            background-color: yellowgreen;
            margin: 0 auto;
        }
        .main {
            /* 父元素(相对定位) */
            position: relative;
        }
        .main .box {
            width: 100px;
            height: 100px;
            background-color: red;

            /*子元素 
            设置.box标签绝对定位*/
            position: absolute;
            /* 正数 往左侧移动; 负数 往右侧移动*/
            right: 100px;
            /* 正数 往上边移动; 负数 往下边移动*/
            bottom: 100px;

            /* 正数 往右侧移动; 负数 往左侧移动*/
            left: 50px;
            /* 正数 往下边移动; 负数 往上边移动*/
            top: 50px;
        }
    </style>
    <div class="header"></div>

    <div class="main">
            <div class="box"></div>
    </div>
    <div class="footer"></div>

希望本文对大家理解和运用 CSS 这些核心属性有所帮助。

标签:设置,color,元素,height,学习,第六天,background,HTMLCSS,left
From: https://blog.csdn.net/2401_83588067/article/details/142457935

相关文章

  • 如何开启项目管理学习之旅?免费助你建立系统知识体系
    活动介绍新时代新挑战,传统公司的结构、传统的企业管理方式、增长策略与决策面对常态化的不确定性时备受挑战。项目经济时代,面对内外部环境的快速变化,企业、组织、个人要如何从容应对?在当下竞争日益激烈的市场环境中,企业需要不断提升自身管理能力来应对各种挑战,而通过内训系统地学习......
  • 苍穹外卖学习日志 -----20天项目从零到完结-----含软件下载,环境配置,框架学习,代码编写,
    年份2024    基础:Javase  Javaweb已完结   2024  8.25---9.14  20天Day-01   8.25今天开始学习已经晚了,网盘下载了一下文件,做了一些开始项目的准备工作。本来其实打算用notepad++来写学习日志的,但是那个传不了图片,而且编辑视图没有这......
  • 【开题报告+文档+源码】基于SSM框架的诗词吟诵知识学习系统的设计与实现
    项目背景与意义随着信息技术的迅猛发展,互联网已经成为人们获取知识的重要途径。特别是在线教育平台的兴起,使得教育资源得以更广泛的传播和利用。为了满足青岛滨海学院学生对吟诵知识学习的需求,本文设计并实现了一个基于SSM(Spring+SpringMVC+MyBatis)框架的吟诵知识学习系统......
  • 基于springboot+vue的高校学生考勤系统-可用于计算机毕设-课程设计-练手学习
    博主简介:......
  • hive学习笔记之二:复杂数据类型
    selectperson,friends[0],friends[3]fromt2;执行结果如下,第一条记录没有friends[3],显示为NULL:hive>selectperson,friends[0],friends[3]fromt2;OKperson _c1 _c2tom tom_friend_0 NULLjerry jerry_friend_0 jerry_friend_3Timetaken:0.052seconds,Fetched:2......
  • jackson学习之五:JsonInclude注解
    本文是《jackson学习》系列第五篇,来熟悉一个常用的注解JsonInclude,该注解的仅在序列化操作时有用,用于控制方法、属性等是否应该被序列化;之所以用单独的一篇来写JsonInclude注解,是因为该注解的值有多种,每种都有不同效果,最好的学习方法就是编码实战;先对注解的所有取值做个简......
  • D15【python接口自动化学习】-python基础之内置数据类型
    day15字典的常见操作(上)学习日期:20240922学习目标:内置数据类型--24常见常新:字典的常见操作(上)学习笔记:字典的内置函数访问字典的内容#访问字典的所有元素mail_list={'tom':'tom@gmail.com','jerry':'jerry@foxmail.com','john':'john@163.com'}print(mail_li......
  • 零基础转行大模型学习路线,存下吧❗❗
    从0⃣-1⃣学习AI大模型,看着一篇就对了从私有化部署、微调、项目实战等多个方面给大家介绍如何✅正确入门AI大模型,涉及的领域范围面广,涵盖各行各业大模型项目落地场景,想学AI大模型这篇资料必备!!......