Python Web开发记录 Day2:CSS

news2025/1/12 9:49:28

名人说:莫道桑榆晚,为霞尚满天。——刘禹锡(刘梦得,诗豪)
创作者:Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊)

目录

      • 二、CSS
        • 1、CSS-初始入门
          • ①快速了解
          • ②CSS应用方式
          • ③选择器
          • ④样式
        • 2、CSS-常见样式和案例
          • ①浮动
          • ②内边距
          • ③外边距
        • 3、CSS-样式和小米商城
          • ①CSS案例
          • ②小结
        • 4、CSS-案例:小米商城新品部分
          • ①案例:推荐区域
          • ②案例实现
        • 5、CSS-边框和背景色
          • ①:hover(伪类)
          • ②:after(伪元素)
          • ③position属性
          • ④relative和absolute定位
          • ⑤border属性
          • ⑥background-color属性

二、CSS

1、CSS-初始入门

HTML vs CSS

1️⃣ 超文本标记语言HTML,使用多种“标签”描述网页的结构和内容。(网页扩展名为.html)

在这里插入图片描述

2️⃣ 层叠样式表CSS从审美角度来描述网页的样式。(文件扩展名为.css)
在这里插入图片描述

CSS,专门用来”美化“标签,HTML如果是"身体",CSS就是在身体外的各种装饰,可以美化HTML写出来的"身体"。

  • 基础CSS,写简单页面 & 看懂 & 修改;
  • 模块,调整和修改。
①快速了解

CSS是一种用于描述HTML或XML(包括各种XML语言,如SVG或XHTML)文档的样式的语言。CSS描述了这些文档在屏幕、纸张、语音阅读器等媒介上的呈现方式。

1.基础概念

  • 选择器(Selectors):用于选择你想要样式化的HTML元素。
  • 属性(Properties):定义了如何样式化元素。
  • 值(Values):属性的具体设置。
  • 声明(Declarations):由属性和值组成,如 color: red;
  • 声明块(Declaration Blocks):用大括号 {} 包围的一系列声明。
  • 规则集(Rule Sets):由选择器和声明块组成。

2.基本语法

selector {
  property: value;
}

示例

p {
  color: red;
  font-size: 14px;
}

这个示例会将所有 <p>(段落)元素的文字颜色设置为红色,并且字体大小为14像素。

3.常用属性

  • color: 文本颜色
  • background-color: 背景色
  • font-size: 字体大小
  • border: 边框
  • margin: 外边距
  • padding: 内边距
  • widthheight: 宽度和高度
<img src="..." style="height:100px"/>

<div style="color:red;">中国联通</div>

4.响应式设计

  • 媒体查询(Media Queries):允许你根据不同的屏幕尺寸或设备特性应用不同的样式。

示例

@media screen and (max-width: 600px) {
  body {
    background-color: lightblue;
  }
}
②CSS应用方式

1.在标签上应用

直接在标签里进行添加。

<img src="..." style="height:100px"/>

<div style="color:red;">中国联通</div>

2.在head标签中写style标签( * )

在头部head标签中添加style标签,在style标签中来进行添加CSS样式。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .c1{
            color:red;
        }
    </style>
</head>
<body>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
      <form method="post" action="/login">
          用户名:<input type="text" name="username">
          密码:<input type="text" name="password">
          <input type="submit" value="提交">
      </form>
</body>
</html>

3.写到文件中( * )

写到文件里,直接使用文件里的样式。

.c1{
   height:100px; 
}

.c2{
    color:red;
}
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
	<link rel="stylesheet" href="common.css" />
</head>
<body>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
    <h1 class='c1'>用户登录</h1>
</body>
</html>

案例:flask中的应用(登录 注册)

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/commons.css">
</head>
<body>
  <h1 class="xx">用户注册</h1>

  <form action="/register" method="post">
  <div>
    用户名: <input type="text" name="user">
  </div>

  <div>
    密码: <input type="password" name="pwd">
  </div>

  <div>
    <input type="submit" value="注册">
  </div>

  </form>
</body>
</html><!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <link rel="stylesheet" href="/static/commons.css">
</head>
<body>
  <h1 class="xx">用户注册</h1>

  <form action="/register" method="post">
  <div>
    用户名: <input type="text" name="user">
  </div>

  <div>
    密码: <input type="password" name="pwd">
  </div>

  <div>
    <input type="submit" value="注册">
  </div>

  </form>
</body>
</html>
.xx{
    color: green;
}

问题:用Flask框架开发有些不便之处:

  • 每次都需要重启
  • 规定有些文件必须要放在特定的文件夹
  • 新创建一个页面
    • 函数
    • HTML文件

有没有一种方式,可以快速编写前端代码及查看响应效果,最后将页面集成到Flask中?

Pycharm为我们提供了一种非常便捷开发前端页面的工具,鼠标滑到界面右侧即可显示,打开此处页面可以实时地看到代码更新所带来的页面变化。

image-20240220170546380

③选择器

在CSS中,选择器用于定位一个或多个元素,以便应用样式。

1.ID选择器

通过HTML元素的id属性选择特定元素。ID是唯一的,在一个HTML页面中,每个ID只能出现一次。ID选择器在CSS中以#字符开始,后跟ID的名称。例如,#navbar选择具有id="navbar"的元素。

#c1{
    
}

<div id='c1'>
    
</div>

2.类选择器(使用较多)

通过HTML元素的class属性选择一个或多个元素。同一类可以应用于页面上的多个元素,一个元素也可以有多个类。类选择器在CSS中以.字符开始,后跟类的名称。例如,.button选择所有具有class="button"的元素。

.c1{

}

<div class='c1'>
    
</div>

3.标签选择器(使用较多)

又称为元素选择器,通过元素名称选择所有特定类型的元素。例如,div选择页面上的所有div元素。

div{

}

<div>
    xxx
</div>																																	

4.属性选择器

根据元素的属性及属性值来选择元素。它们用方括号[]表示,内部可以指定属性名,也可以指定属性名和值。例如,[type=“text”]选择所有type属性值为text的元素。

input[type='text']{
	border:1px solid red;
}

.v1[xx="456"]{
	color: gold;
}
<input type="text">
<input type="password">

<div class="v1" xx="123">
    s
</div>

<div class="v1" xx="456">
    f
</div>

<div class="v1" xx="999">
    a
</div>

在这里插入图片描述

5.后代选择器(使用较多)

用于选择一个元素的后代元素,即位于指定元素内部的元素,不论是直接还是间接后代。后代选择器通过空格分隔父元素和子元素的选择器来表示。例如,div p选择所有位于div元素内部的p元素。

      .yy li{
          color: pink;
      }

      .yy > a{
          color: dodgerblue;
      }
<div class="yy">
            <a>百度</a>
            <div>
                <a>谷歌</a>
            </div>
            <ul>
                <li>美国</li>
                <li>日本</li>
                <li>韩国</li>
            </ul>
      </div>

在这里插入图片描述

关于选择器:

日常使用多少:
多:类选择器、标签选择器、后代选择器
少:属性选择器、ID选择器

关于多个样式和覆盖的问题:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1{
        color: red !important;
        border: 1px solid red;
      }
      .c2{
        font-size: 28px;
        color: green;
      }
    </style>
</head>
<body>
    <div class="c1 c2">中国联通</div>
</body>
</html>

在这里插入图片描述

④样式

1.高度和宽度

.c1{
	/*height高度 width宽度*/
    height:300px;
    width:500px;
}

注意:

  • 宽度,支持百分比。
  • 行内标签:默认无效
  • 块级标签:默认有效(霸道,右侧区域空白,也不给你占用)

2.块级和行内标签

  • 块级
  • 行内
  • CSS样式:标签-> display:inline-block

示例1:行内+块级特性

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .c1{
            display: inline-block;

            height: 100px;
            width: 300px;
            border: 1px solid red;
        }
    </style>
</head>
<body>
    <span class="c1">中国</span>
    <span class="c1">联通</span>
    <span class="c1">联通</span>
    <span class="c1">联通</span>
</body>
</html>

在这里插入图片描述

示例2:块级和行内标签的设置

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>

    </style>
</head>
<body>
    <div style="display: inline;">中国</div>
    <span style="display: block;">联通</span>
</body>
</html>

在这里插入图片描述

注意:块级+跨级和行内

3.字体设置

  • 颜色 color
  • 大小 font-size
  • 加粗 font-weight
  • 字体格式 font-family
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1{
        color: #66CDAA;
        font-size: 50px;
        font-weight: 500;
        font-family:"Microsoft Yahei";
      }
    </style>
</head>
<body>
    <div class="c1">中国联通</div>
    <div>中国移动</div>
</body>
</html>

在这里插入图片描述

4.文字对齐方式

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .c1{
            height: 59px;
            width: 300px;
            border: 1px solid red;

            text-align: center; /*水平方向居中*/
            line-height: 59px; /*垂直方向居中*/
        }
    </style>
</head>
<body>
      <div class="c1">张三</div>
</body>
</html>

在这里插入图片描述

2、CSS-常见样式和案例
①浮动
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
      <div>
        <span>左边</span>
        <span style="float: right">右边</span>
      </div>
</body>
</html>

在这里插入图片描述

div默认块级标签(比较霸道),如果浮动起来,就不一样了。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .item{
          float: left;
          width: 280px;
          height: 170px;
          border: 1px solid red;
        }
    </style>
</head>
<body>
      <div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
      </div>
</body>
</html>

在这里插入图片描述

可是如果你让标签浮动起来之后,就会脱离文档流,那该怎么解决呢?

可以通过添加这个语句<div style="clear: both"></div>解决。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .item{
          float: left;
          width: 280px;
          height: 170px;
          border: 1px solid red;
        }
    </style>
</head>
<body>
      <div style="background-color: dodgerblue">
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div class="item"></div>
        <div style="clear: both"></div>
      </div>
      <div>你好</div>

</body>
</html>

在这里插入图片描述

为什么添加<div style="clear: both"></div>能够解决呢?

在HTML中,<div style="clear: both"></div> 用于控制布局,特别是在使用浮动(float)元素时。浮动元素会脱离文档流的正常排列,可能导致布局混乱。clear 属性用来清除元素的左侧、右侧或两侧的浮动,确保不会有浮动元素影响到它的布局。

具体来说,clear: both; 表示清除前面元素的左右浮动,使得接下来的内容显示在浮动元素的下方,而不是旁边或者覆盖浮动元素。这个技术常用于确保父容器能够包含其内部浮动的子元素,防止布局错乱。

例如,如果你有几个浮动的 <div> 元素用于创建并排的布局,之后你希望接下来的内容不受这些浮动元素的影响,显示在它们下面,那么可以在浮动元素之后使用 <div style="clear: both"></div> 来实现这个布局需求。这样,它会创建一个不可见的分界线,确保浮动不会影响到后续的内容布局。

②内边距

内部距离,自己内部的距离

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
         .outer{
           border: 1px solid red;
           height: 200px;
           width: 200px;
           padding-top: 20px;
           padding-left: 20px;
           padding-right: 20px;
           padding-bottom: 20px;
         }
    </style>
</head>
<body>
      <div class="outer">
          <div style="background-color: gold">听妈妈的话</div>
          <div>
            小朋友你是否有很多问号?
          </div>
      </div>
</body>
</html>
③外边距

外部距离,自己与别人之间的距离

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
</head>
<body>
      <div style="height: 200px;background-color: dodgerblue"></div>
      <div style="background-color: red;height: 100px; margin-top: 20px"></div>
</body>
</html>

综合案例:小米商城

案例1 小米商城顶部

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        body{
          margin: 0;
        }

        .header{
              background: #333;
        }

        .container{
            width: 1226px;
            margin: 0 auto;
        }

        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }

        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }

        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
        }
    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a>小米官网</a>
                  <a>小米商城</a>
                  <a>小米澎湃OS</a>
                  <a>云服务</a>
                  <a>小爱开放平台</a>
                  <a>下载app</a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
</body>
</html>

image-20240221141612522

小结

  • body标签,默认有一个边距,会造成页面四周有白色间隙,如何去除?
body{
	margin:0;
}
  • 内容居中

    • 文本居中

      <div style="width: 200px; background-color:pink; text-align: center">张三</div>
      
    • 区域居中,自己要有宽度 + margin-left:auto; margin-right:auto;

    .container{
    	width: 980px;
     	margin: 0 auto;
    }
    
    <div class="container">
        asddqsadas
    </div>
    
  • 父亲没有高度或没有宽度,被孩子支撑起来。

  • 如果存在浮动,要加上<div style="clear:both"></div>

  • 如果想用别人实现的样式

  • 关于布局,不知道如何下手的话,学会分析页面的布局

image-20240221150848747

3、CSS-样式和小米商城
  • 案例应用(利用之前所学知识)
  • CSS知识点
  • 模版 + CSS + 构建页面
①CSS案例

1.内容回顾

  • HTML标签

    固定格式,记住标签长什么样,例如:
    h / div / span / a / img / ul / li / table / input / form
    
  • CSS样式

    引用CSS:标签、头部、文件

    .xx{
    	...
    }
    
    <div class='xx xx'></div>
    
    高度height / 宽度width /块级 or 行内 or 块级行内 / 浮动float / 字体font / 文字对齐方式text-align / 内边距 / 外边距
    
    关于边距:
    	- body
    	- 区域居中
    
  • 页面布局

    根据你看到的页面把他们划分成很多小的区域,再去填充样式。
    

2.案例:二级菜单

a.分析布局

image-20240221152034178

b.搭建骨架

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>二级菜单</title>
    <style>
        .sub-header{
            height: 100px;
            background-color: #b0b0b0;
        }

        .container{
            width: 1128px;
            margin: 0 auto;
        }

        .sub-header .ht{
            height: 100px;

        }
        .sub-header .logo{
            width: 234px;
            float: left;
        }

        .sub-header .menu-list{
            float: left;
        }

        .sub-header .search{
            float: right;
        }
    </style>
</head>
<body>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">1</div>
            <div class="ht menu-list">2</div>
            <div class="ht search">3</div>
            <div style="clear: both"></div>
        </div>
      </div>
      <div>
          <div class="logo"></div>
      </div>
</body>
</html>

image-20240221234224590

c.完善logo区域

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>二级菜单</title>
    <style>
        .sub-header{
            height: 100px;
            background-color: #b0b0b0;
        }

        .container{
            width: 1128px;
            margin: 0 auto;
        }

        .sub-header .ht{
            height: 100px;

        }
        .sub-header .logo{
            width: 234px;
            float: left;
            border: 1px solid red;
            line-height: 100px;
        }

        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block
        }

        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }

        .sub-header .menu-list{
            float: left;
        }

        .sub-header .search{
            float: right;
        }
    </style>
</head>
<body>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <!--a,行内标签,默认设置高度、边距无效 解决:转换成块级 OR 行内&块级-->
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>
            <div class="ht menu-list">2</div>
            <div class="ht search">3</div>
            <div style="clear: both"></div>
        </div>
      </div>
      <div>
          <div class="logo"></div>
      </div>
</body>
</html>

在这里插入图片描述

d.布置菜单区域

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>二级菜单</title>
    <style>
        .sub-header{
            height: 100px;
        }

        .container{
            width: 1128px;
            margin: 0 auto;
        }

        .sub-header .ht{
            height: 100px;

        }
        .sub-header .logo{
            width: 234px;
            float: left;

            line-height: 100px;
        }

        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block
        }

        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }

        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }

        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }

        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        
        .sub-header .search{
            float: right;
        }
    </style>
</head>
<body>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <!--a,行内标签,默认设置高度、边距无效 解决:转换成块级 OR 行内&块级-->
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>
            <div class="ht search">3</div>
            <div style="clear: both"></div>
        </div>
      </div>
      <div>
          <div class="logo"></div>
      </div>
</body>
</html>

在这里插入图片描述

3.综合案例:顶部菜单+二级菜单

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小米顶部</title>
    <style>
        body{
          margin: 0;
        }
        .header{
              background: #333;
        }
        .container{
            width: 1226px;
            margin: 0 auto;
        }
        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
                text-decoration: none;
        }

        .header a:hover{
            color: white;
        }

        .sub-header{
            height: 100px;
        }
        .sub-header .ht{
            height: 100px;
        }
        .sub-header .logo{
            width: 234px;
            float: left;
            line-height: 100px;
        }
        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block;
        }
        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }
        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }
        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }
        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        .sub-header .search{
            float: right;
            padding-top: 35px; /* Adjust padding to align search box as needed */
        }
        .search input[type="text"]{
                right: 51px;
                z-index: 1;
                width: 223px;
                height: 48px;
                padding: 0 10px;
                font-size: 14px;
                line-height: 48px;
                vertical-align: middle;
        }
        .search input[type="submit"]{
                right: 0;
                z-index: 2;
                width: 52px;
                height: 50px;
                font-size: 24px;
                line-height: 24px;
                background: #fff;
                color: #616161;
        }

        .search-btn {
                background: url('/images/search.png') no-repeat center center; /* 搜索图标的路径 */
                border: 1px solid;
                cursor: pointer; /* 鼠标悬停时显示手形图标 */
                width: 52px;
                height: 50px;
                background-size: contain; /* 使背景图像适应按钮大小 */
                vertical-align: middle;
        }

         /*可能需要的额外样式调整*/
        .search-btn:focus {
                outline: none; /* 移除聚焦时的轮廓线 */
        }

    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a href="https://www.mi.com/shop">小米官网</a>
                  <a href="https://www.mi.com/shop">小米商城</a>
                  <a href="https://www.mi.com/shop">小米澎湃OS</a>
                  <a href="https://www.mi.com/shop">云服务</a>
                  <a href="https://www.mi.com/shop">小爱开放平台</a>
                  <a href="https://www.mi.com/shop">下载app</a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>

             <div class="ht search">
                <form action="/search" method="get">
                    <input type="text" name="q" placeholder="搜索产品" required>
                    <input type="image" src="/images/search.png" alt="搜索" class="search-btn iconfont">
                </form>
            </div>

            <div style="clear: both"></div>
        </div>
      </div>
</body>
</html>

image-20240222010448250

②小结
  • a标签是行内标签,行内标签的高度、内外边距,默认无效。

  • 垂直方向居中

    • 文本 line-height
    • 图片 边距
  • a标签默认有下划线

  • 鼠标放上去之后hover

    .c1:hover{
        ...
    }
    a:hover{
        
    }
    
4、CSS-案例:小米商城新品部分
①案例:推荐区域

1.划分区域

image-20240222134445323

2.搭建骨架

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小米顶部</title>
    <style>
        body{
          margin: 0;
        }
        .header{
              background: #333;
        }
        .container{
            width: 1226px;
            margin: 0 auto;
        }
        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
                text-decoration: none;
        }

        .header a:hover{
            color: white;
        }

        .sub-header{
            height: 100px;
        }
        .sub-header .ht{
            height: 100px;
        }
        .sub-header .logo{
            width: 234px;
            float: left;
            line-height: 100px;
        }
        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block;
        }
        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }
        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }
        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }
        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        .sub-header .search{
            float: right;
            padding-top: 35px; /* Adjust padding to align search box as needed */
        }
        .search input[type="text"]{
                right: 51px;
                z-index: 1;
                width: 223px;
                height: 48px;
                padding: 0 10px;
                font-size: 14px;
                line-height: 48px;
                vertical-align: middle;
        }
        .search input[type="submit"]{
                right: 0;
                z-index: 2;
                width: 52px;
                height: 50px;
                font-size: 24px;
                line-height: 24px;
                background: #fff;
                color: #616161;
        }

        .search-btn {
                background: url('/images/search.png') no-repeat center center; /* 搜索图标的路径 */
                border: 1px solid;
                cursor: pointer; /* 鼠标悬停时显示手形图标 */
                width: 52px;
                height: 50px;
                background-size: contain; /* 使背景图像适应按钮大小 */
                vertical-align: middle;
        }

         /*可能需要的额外样式调整*/
        .search-btn:focus {
                outline: none; /* 移除聚焦时的轮廓线 */
        }

        .slider img{
            width: 1226px;
            height: 460px;
            text-align: right;
        }

    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a href="https://www.mi.com/shop">小米官网</a>
                  <a href="https://www.mi.com/shop">小米商城</a>
                  <a href="https://www.mi.com/shop">小米澎湃OS</a>
                  <a href="https://www.mi.com/shop">云服务</a>
                  <a href="https://www.mi.com/shop">小爱开放平台</a>
                  <a href="https://www.mi.com/shop">下载app</a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>

             <div class="ht search">
                <form action="/search" method="get">
                    <input type="text" name="q" placeholder="搜索产品" required>
                    <input type="image" src="/images/search.png" alt="搜索" class="search-btn iconfont">
                </form>
            </div>

            <div style="clear: both"></div>
        </div>
      </div>
      <div class="slider">
          <div class="container">
              <div class="sd-img">
                  <img src="images/b1.jpg" alt="">
              </div>
          </div>
      </div>
      <div class="news">
          <div class="container">
              <div class="channel"></div>
              <div class="list-item"></div>
              <div class="list-item"></div>
              <div class="list-item"></div>
          </div>
      </div>

</body>
</html>

在这里插入图片描述

②案例实现
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小米顶部</title>
    <style>
        body{
          margin: 0;
        }
        .header{
              background: #333;
        }
        .container{
            width: 1226px;
            margin: 0 auto;
        }

        .left{
            float: left;
        }
        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
                text-decoration: none;
        }

        .header a:hover{
            color: white;
        }

        .sub-header{
            height: 100px;
        }
        .sub-header .ht{
            height: 100px;
        }
        .sub-header .logo{
            width: 234px;
            float: left;
            line-height: 100px;
        }
        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block;
        }
        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }
        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }
        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }
        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        .sub-header .search{
            float: right;
            padding-top: 35px; /* Adjust padding to align search box as needed */
        }
        .search input[type="text"]{
                right: 51px;
                z-index: 1;
                width: 223px;
                height: 48px;
                padding: 0 10px;
                font-size: 14px;
                line-height: 48px;
                vertical-align: middle;
        }
        .search input[type="submit"]{
                right: 0;
                z-index: 2;
                width: 52px;
                height: 50px;
                font-size: 24px;
                line-height: 24px;
                background: #fff;
                color: #616161;
        }

        .search-btn {
                background: url('/images/search.png') no-repeat center center; /* 搜索图标的路径 */
                border: 1px solid;
                cursor: pointer; /* 鼠标悬停时显示手形图标 */
                width: 52px;
                height: 50px;
                background-size: contain; /* 使背景图像适应按钮大小 */
                vertical-align: middle;
        }

         /*可能需要的额外样式调整*/
        .search-btn:focus {
                outline: none; /* 移除聚焦时的轮廓线 */
        }

        .slider img{
            width: 1226px;
            height: 460px;
            text-align: right;
        }

        .news{
            margin-top: 14px;
        }
        .news .channel{
            width: 228px;
            height: 164px;
            background-color:#5f5750;
            padding: 3px;
        }

        .news .channel .item img{
            display: block;
            width: 24px;
            height: 24px;
            margin: 0 auto 4px;
        }

        .news .channel .item{
            height: 82px;
            width: 76px;
            float: left;
            text-align: center;
        }

        .news .channel .item a{
            display: inline-block;
            font-size: 12px;
            padding-top: 18px;
            color: #ffffff;
            text-decoration: none;
            opacity: 0.7;
        }

        .news .channel .item a:hover{
            opacity: 1;
        }

        .news .list-item img{
            width: 316px;
            height: 170px;
            display: block;
            margin: 0 auto 4px;
        }
    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a href="https://www.mi.com/shop">小米官网</a>
                  <a href="https://www.mi.com/shop">小米商城</a>
                  <a href="https://www.mi.com/shop">小米澎湃OS</a>
                  <a href="https://www.mi.com/shop">云服务</a>
                  <a href="https://www.mi.com/shop">小爱开放平台</a>
                  <a href="https://www.mi.com/shop">下载app</a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>

             <div class="ht search">
                <form action="/search" method="get">
                    <input type="text" name="q" placeholder="搜索产品" required>
                    <input type="image" src="/images/search.png" alt="搜索" class="search-btn iconfont">
                </form>
            </div>

            <div style="clear: both"></div>
        </div>
      </div>
      <div class="slider">
          <div class="container">
              <div class="sd-img">
                  <img src="images/b1.jpg" alt="">
              </div>
          </div>
      </div>
      <div class="news">
          <div class="container">
              <div class="channel left">
                  <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c1.png" alt="">
                          <span>保障服务</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c2.png" alt="">
                          <span>企业团购</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c3.png" alt="">
                          <span>F码通道</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c4.png" alt="">
                          <span>米粉卡</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c5.png" alt="">
                          <span>以旧换新</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c6.png" alt="">
                          <span>话费充值</span>
                      </a>
                  </div>
                  <div class="clear:both"></div>
              </div>
              <div class="list-item left" style="margin-left: 14px">
                  <img src="/images/w1.png" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w2.jpg" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w3.png" alt="">
              </div>
          </div>
      </div>

</body>
</html>

image-20240222155515219

  • 设置透明度
    通过opacity来设置

    opacity:0.5 /* 透明度为0.5 透明度范围:0~1 */
    

image-20240222155824362

5、CSS-边框和背景色
①:hover(伪类)

用于定义鼠标悬停在元素上时的样式。例如,a:hover { color: red; }会使链接在鼠标悬停时变为红色。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1{
          color: red;
          font-size: 18px;
      }
      
      .c1:hover{
        color: green;
        font-size: 50px;
      }
      
      .c2{
          height: 300px;
          width: 500px;
          border: 3px solid red;
      }

      .c2:hover{
          border: 3px solid green;
      }

      .download{
          display: none;
      }

      .app:hover .download{
          display: block;
      }

      .app:hover .title{
          color: yellowgreen;
      }
    </style>
</head>
<body>
      <div class="c1">联通</div>
      <div class="c2">广西</div>

      <div class="app">
          <div class="title">下载App</div>
          <div class="download">
              <img src="images/QRcode.png" alt="">
          </div>
      </div>
</body>
</html>

在这里插入图片描述

②:after(伪元素)

用于在元素的内容之后插入额外的内容。它通常与content属性一起使用。例如,p:after { content: “Read more”; }会在所有p元素的内容后添加"Read more"文本。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1:after{
        content:"大帅哥";
      }
    </style>
</head>
<body>
    <div class="c1">张三</div>
    <div class="c1">李四</div>
</body>
</html>

很重要的应用,可以清除浮动,以免脱离文档流。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
        .clearfix:after{
            content: "";
            display: block;
            clear: both;
        }
        .item{
            float: left;
        }
    </style>
</head>
<body>
    <div class="clearfix">
        <div class="item">1</div>
        <div class="item">2</div>
        <div class="item">3</div>
    </div>
</body>
</html>
③position属性

用于设置元素的定位方式。它的值可以是static、relative、absolute、fixed或sticky,分别对应不同的定位行为。常用的三个方式如下:

  • fixed
  • relative
  • absolute

a.fixed

固定在窗口的某个位置

案例1:返回顶部

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小米顶部</title>
    <style>
        body{
          margin: 0;
        }
        .header{
              background: #333;
        }
        .container{
            width: 1226px;
            margin: 0 auto;
        }

        .left{
            float: left;
        }
        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
                text-decoration: none;
        }

        .header a:hover{
            color: white;
        }

        .sub-header{
            height: 100px;
        }
        .sub-header .ht{
            height: 100px;
        }
        .sub-header .logo{
            width: 234px;
            float: left;
            line-height: 100px;
        }
        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block;
        }
        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }
        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }
        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }
        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        .sub-header .search{
            float: right;
            padding-top: 35px; /* Adjust padding to align search box as needed */
        }
        .search input[type="text"]{
                right: 51px;
                z-index: 1;
                width: 223px;
                height: 48px;
                padding: 0 10px;
                font-size: 14px;
                line-height: 48px;
                vertical-align: middle;
        }
        .search input[type="submit"]{
                right: 0;
                z-index: 2;
                width: 52px;
                height: 50px;
                font-size: 24px;
                line-height: 24px;
                background: #fff;
                color: #616161;
        }

        .search-btn {
                background: url('/images/search.png') no-repeat center center; /* 搜索图标的路径 */
                border: 1px solid;
                cursor: pointer; /* 鼠标悬停时显示手形图标 */
                width: 52px;
                height: 50px;
                background-size: contain; /* 使背景图像适应按钮大小 */
                vertical-align: middle;
        }

         /*可能需要的额外样式调整*/
        .search-btn:focus {
                outline: none; /* 移除聚焦时的轮廓线 */
        }

        .slider img{
            width: 1226px;
            height: 460px;
            text-align: right;
        }

        .news{
            margin-top: 14px;
        }
        .news .channel{
            width: 228px;
            height: 164px;
            background-color:#5f5750;
            padding: 3px;
        }

        .news .channel .item img{
            display: block;
            width: 24px;
            height: 24px;
            margin: 0 auto 4px;
        }

        .news .channel .item{
            height: 82px;
            width: 76px;
            float: left;
            text-align: center;
        }

        .news .channel .item a{
            display: inline-block;
            font-size: 12px;
            padding-top: 18px;
            color: #ffffff;
            text-decoration: none;
            opacity: 0.7;
        }

        .news .channel .item a:hover{
            opacity: 1;
        }

        .news .list-item img{
            width: 316px;
            height: 170px;
            display: block;
            margin: 0 auto 4px;
        }

        .back{
          position: fixed;
          width: 60px;
          height: 60px;
          border: 1px solid red;

          right: 10px;
          bottom: 50px;
        }
    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a href="https://www.mi.com/shop">小米官网</a>
                  <a href="https://www.mi.com/shop">小米商城</a>
                  <a href="https://www.mi.com/shop">小米澎湃OS</a>
                  <a href="https://www.mi.com/shop">云服务</a>
                  <a href="https://www.mi.com/shop">小爱开放平台</a>
                  <a href="https://www.mi.com/shop">下载app</a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>

             <div class="ht search">
                <form action="/search" method="get">
                    <input type="text" name="q" placeholder="搜索产品" required>
                    <input type="image" src="/images/search.png" alt="搜索" class="search-btn iconfont">
                </form>
            </div>

            <div style="clear: both"></div>
        </div>
      </div>
      <div class="slider">
          <div class="container">
              <div class="sd-img">
                  <img src="images/b1.jpg" alt="">
              </div>
          </div>
      </div>
      <div class="news">
          <div class="container">
              <div class="channel left">
                  <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c1.png" alt="">
                          <span>保障服务</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c2.png" alt="">
                          <span>企业团购</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c3.png" alt="">
                          <span>F码通道</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c4.png" alt="">
                          <span>米粉卡</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c5.png" alt="">
                          <span>以旧换新</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c6.png" alt="">
                          <span>话费充值</span>
                      </a>
                  </div>
                  <div class="clear:both"></div>
              </div>
              <div class="list-item left" style="margin-left: 14px">
                  <img src="/images/w1.png" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w2.jpg" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w3.png" alt="">
              </div>
          </div>
      </div>

      <div style="height: 1000px;"></div>
      <div class="back"></div>
</body>
</html>

在这里插入图片描述

案例2:对话框

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      body{
        margin: 0;
      }
      .dialog{
        position: fixed;
        height: 300px;
        width: 500px;
        background-color: white;
        
        /*left: 50%;*/
        /*margin-left: -250px;*/

        left: 0;
        right: 0;
        margin: 0 auto;

        top: 200px;
        z-index: 1000;
      }
      .mask{
        background-color: black;
        position: fixed;
        left: 0px;
        right: 0px;
        top: 0px;
        bottom: 0px;
        opacity: 0.7;
        z-index: 999;
      }
    </style>
</head>
<body>
      <div class="mask"></div>

      <div style="height: 1000px;">qwewqeqw</div>

      <div class="dialog"></div>
</body>
</html>

在这里插入图片描述

④relative和absolute定位
  • relative定位:是position属性的一个值,表示元素将相对于其正常位置进行定位。也就是说,即使你对元素应用了定位,它仍然占据原来的空间,但可以通过top、right、bottom、left属性移动位置。

  • absolute定位:也是position属性的一个值,表示元素相对于最近的已定位的祖先元素(不是static定位的元素)进行定位。如果没有这样的元素,则相对于文档体()元素定位。绝对定位的元素不占据文档流中的空间。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
          .c1{
            height: 300px;
            width: 500px;
            border: 1px solid red;
            margin: 100px;
            position: relative;
          }
          
          .c1 .c2{
            height: 59px;
            width: 59px;
            background-color: #00FF7F;

            position: absolute;
            right: 20px;
            bottom: 10px;
          }
    </style>
</head>
<body>
      <div class="c1">

        <div class="c2"></div>


      </div>
</body>
</html>

案例1:小米商城下载app

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>小米顶部</title>
    <style>
        body{
          margin: 0;
        }
        .header{
              background: #333;
        }
        .container{
            width: 1226px;
            margin: 0 auto;
        }

        .left{
            float: left;
        }
        .header .menu{
          float: left;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header .account{
          float: right;
          color: white;
          height: 38px;
          line-height: 38px;
        }
        .header a{
                color: #b0b0b0;
                line-height: 40px;
                display: inline-block;
                font-size: 12px;
                margin-right: 10px;
                text-decoration: none;
        }

        .header a:hover{
            color: white;
        }

        .sub-header{
            height: 100px;
        }
        .sub-header .ht{
            height: 100px;
        }
        .sub-header .logo{
            width: 234px;
            float: left;
            line-height: 100px;
        }
        .sub-header .logo a{
            margin-top: 22px;
            display: inline-block;
        }
        .sub-header .logo a img{
            height: 56px;
            width: 56px;
        }
        .sub-header .menu-list{
            float: left;
            line-height: 100px;
        }
        .sub-header .menu-list a{
            display: inline-block;
            padding: 0 10px;
            color: #333;
            font-size: 16px;
            text-decoration: none;
        }
        .sub-header .menu-list a:hover{
            color: #ff6700;
        }
        .sub-header .search{
            float: right;
            padding-top: 35px; /* Adjust padding to align search box as needed */
        }
        .search input[type="text"]{
                right: 51px;
                z-index: 1;
                width: 223px;
                height: 48px;
                padding: 0 10px;
                font-size: 14px;
                line-height: 48px;
                vertical-align: middle;
        }
        .search input[type="submit"]{
                right: 0;
                z-index: 2;
                width: 52px;
                height: 50px;
                font-size: 24px;
                line-height: 24px;
                background: #fff;
                color: #616161;
        }

        .search-btn {
                background: url('/images/search.png') no-repeat center center; /* 搜索图标的路径 */
                border: 1px solid;
                cursor: pointer; /* 鼠标悬停时显示手形图标 */
                width: 52px;
                height: 50px;
                background-size: contain; /* 使背景图像适应按钮大小 */
                vertical-align: middle;
        }

         /*可能需要的额外样式调整*/
        .search-btn:focus {
                outline: none; /* 移除聚焦时的轮廓线 */
        }

        .slider img{
            width: 1226px;
            height: 460px;
            text-align: right;
        }

        .news{
            margin-top: 14px;
        }
        .news .channel{
            width: 228px;
            height: 164px;
            background-color:#5f5750;
            padding: 3px;
        }

        .news .channel .item img{
            display: block;
            width: 24px;
            height: 24px;
            margin: 0 auto 4px;
        }

        .news .channel .item{
            height: 82px;
            width: 76px;
            float: left;
            text-align: center;
        }

        .news .channel .item a{
            display: inline-block;
            font-size: 12px;
            padding-top: 18px;
            color: #ffffff;
            text-decoration: none;
            opacity: 0.7;
        }

        .news .channel .item a:hover{
            opacity: 1;
        }

        .news .list-item img{
            width: 316px;
            height: 170px;
            display: block;
            margin: 0 auto 4px;
        }

        .app .download{
            position: absolute;
            height: 100px;
            width: 100px;
            display: none;
        }

        .app .download img{
          height: 100px;
          width: 100px;
        }
        .app:hover .download{
          display: block;
        }
    </style>
</head>
<body>
      <div class="header">
          <div class="container">
              <div class="menu">
                  <a href="https://www.mi.com/shop">小米官网</a>
                  <a href="https://www.mi.com/shop">小米商城</a>
                  <a href="https://www.mi.com/shop">小米澎湃OS</a>
                  <a href="https://www.mi.com/shop">云服务</a>
                  <a href="https://www.mi.com/shop">小爱开放平台</a>
                  <a href="https://www.mi.com/shop" class="app">下载app
                      <div  class="download">
                        <img src="images/QRcode.png" alt="">
                      </div>
                  </a>
              </div>
              <div class="account">
                  <a>登录</a>
                  <a>注册</a>
                  <a>消息通知</a>
              </div>
              <div style="clear:both"></div>
          </div>
      </div>
      <div class="sub-header">
        <div class="container">
            <div class="ht logo">
                <a href="https://www.mi.com/shop" style="margin-top: 22px;display: inline-block">
                    <img src="images/logo-mi2.png" style="height: 56px; width:56px;"alt="">
                </a>
            </div>

            <div class="ht menu-list">
                <a href="https://www.mi.com/shop">Xiaomi手机</a>
                <a href="https://www.mi.com/shop">Redmi手机</a>
                <a href="https://www.mi.com/shop">电视</a>
                <a href="https://www.mi.com/shop">电笔记本</a>
                <a href="https://www.mi.com/shop">平板</a>
                <a href="https://www.mi.com/shop">家电</a>
                <a href="https://www.mi.com/shop">路由器</a>
            </div>

             <div class="ht search">
                <form action="/search" method="get">
                    <input type="text" name="q" placeholder="搜索产品" required>
                    <input type="image" src="/images/search.png" alt="搜索" class="search-btn iconfont">
                </form>
            </div>

            <div style="clear: both"></div>
        </div>
      </div>
      <div class="slider">
          <div class="container">
              <div class="sd-img">
                  <img src="images/b1.jpg" alt="">
              </div>
          </div>
      </div>
      <div class="news">
          <div class="container">
              <div class="channel left">
                  <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c1.png" alt="">
                          <span>保障服务</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c2.png" alt="">
                          <span>企业团购</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c3.png" alt="">
                          <span>F码通道</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c4.png" alt="">
                          <span>米粉卡</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c5.png" alt="">
                          <span>以旧换新</span>
                      </a>
                  </div>
                 <div class="item">
                      <a href="https://www.mi.com/shop">
                          <img src="images/c6.png" alt="">
                          <span>话费充值</span>
                      </a>
                  </div>
                  <div class="clear:both"></div>
              </div>
              <div class="list-item left" style="margin-left: 14px">
                  <img src="/images/w1.png" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w2.jpg" alt="">
              </div>
              <div class="list-item left" style="margin-left: 15px">
                  <img src="/images/w3.png" alt="">
              </div>
          </div>
      </div>

</body>
</html>

image-20240222213251562

⑤border属性

用于设置元素边框的样式、宽度和颜色。例如,border: 1px solid black;会给元素添加一条1像素宽、实线、黑色的边框。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1{
        height: 50px;
        width: 500px;
        /*1、边框粗细3px 2、实线 solid/虚线 dotted 3、边框颜色red*/
        /*border: 3px solid red;*/
        /*border-left: 3px solid transparent;*/
        margin: 100px;
        background-color: #5f5750;
        border-left: 2px solid transparent;
        /*position: relative;*/
      }

      .c1:hover{
          border-left: 2px solid red;
      }
    </style>
</head>
<body>
    <div class="c1">菜单</div>
</body>
</html>

image-20240222214046179

⑥background-color属性

用于设置元素的背景颜色。例如,background-color: blue;会将元素的背景颜色设置为蓝色。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>Title</title>
    <style>
      .c1{
        height: 50px;
        width: 500px;
        margin: 100px;
        background-color: #66CDAA;
      }
    </style>
</head>
<body>
    <div class="c1">菜单</div>
</body>
</html>

在这里插入图片描述

注意:以上不是所有的CSS样式,上述仅为开发中常用的核心知识点,通过此篇内容可以帮助你大致了解页面的样式和标签:

后续会了解一些模版,内容包括:

  • 模版的基本使用逻辑
  • 模版 + 自己CSS知识点(开发页面)

很感谢你能看到这里,如有相关疑问,还请下方评论留言。
笔记记录来源:B站 python的web开发全家桶(django+前端+数据库)
Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊)
如果对大家有帮助的话,希望大家能多多点赞+关注!这样我的动力会更足!

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

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

相关文章

(3)llvm ir转换过程

&#xff08;1&#xff09;DAG Lowering 输入的IR转换成SelectionDAG的过程被称作lowering 就是把llvm ir转成这种 &#xff08;2&#xff09;DAG legalization "DAG legalization"&#xff08;有向无环图合法化&#xff09;是编译器后端&#xff0c;特别是在LLVM中…

React18源码: reconciler执行流程

reconciler执行流程 1 &#xff09;概述 此处先归纳一下react-reconciler包的主要作用&#xff0c;将主要功能分为4个方面&#xff1a; 输入&#xff1a;暴露api函数&#xff08;如&#xff1a;scheduleUpdateOnFiber&#xff09;, 供给其他包&#xff08;如react包&#xff0…

《数字通信世界》杂志社数字通信世界杂志社2024年第1期目录

技术研究 基于B/S架构的海量空间数据并行上传方法研究 刘春伟; 1-348 城市轨道交通工程建设安全数据融合路径及方法 刘魁刚;张瑜;毕鹏;赵智涛;王春勇; 4-6 信息化背景下智慧社区的建设研究 崔宏尧;刘敏智;于志宏;李杰;殷秀莉; 7-9 基于数字孪生技术的工业机器人…

通俗易懂理解G-GhostNet轻量级神经网络模型

一、参考资料 原始论文&#xff1a;[1] IJCV22 | 已开源 | 华为GhostNet再升级&#xff0c;全系列硬件上最优极简AI网络 二、G-GhostNet相关介绍 G-GhostNet 又称为 GhostNetV1 的升级版&#xff0c;是针对GPU优化的轻量级神经网络。 1. 摘要 GhostNetV1 作为近年来最流行…

力扣随笔之通过删除字母匹配到字典里最长单词(中等524)

思路&#xff1a;根据题意有两个问题待解决 1、s字符串中是否可以通过删减得到该英语词语 2、如何找到长度最长且字母序最小的字符串 针对第二个问题可以对词典dictionary进行预处理&#xff1a;根据长度降序和字母序升序来排序 针对第一个问题可以初始化两个指针i&#xff0c;…

Leetcode日记 889. 根据前序和后序遍历构造二叉树

Leetcode日记 889. 根据前序和后序遍历构造二叉树 给定两个整数数组&#xff0c;preorder 和 postorder &#xff0c;其中 preorder 是一个具有 无重复 值的二叉树的前序遍历&#xff0c;postorder 是同一棵树的后序遍历&#xff0c;重构并返回二叉树。 如果存在多个答案&#…

设计模式之委派模式

文章目录 前言正文一、生活中的例子二、Java代码实现2.1 类设计2.2 代码实现2.2.1 Employee2.2.2 ArchitectureDesignEmployer2.2.3 BackEmployer2.2.4 FrontEmployer2.2.5 Leader2.2.6 EmployeeStrongPointEnum2.2.7 Boss 2.3 测试2.3.1 Client2.3.2 测试结果 三、委派模式的优…

Hackme 1

信息收集 Nmap部分 存活扫描&#xff1a; └─# nmap -sn 192.168.10.1/24 Starting Nmap 7.94SVN ( https://nmap.org ) at 2024-02-20 15:00 CST Nmap scan report for 192.168.10.1 (192.168.10.1) Host is up (0.00012s latency). MAC Address: 00:50:56:C0:00:08 (VMwar…

【vue js】将数组元素,按照2个一组,重组为2维数组

实现效果&#xff1a; 要实现上述&#xff0c;2张图片为一个走马灯的内容&#xff0c;而后端传回的数据是一个数组。我采用的是将数据重组为2维数组的方法。 因为没有强制要求展示顺序&#xff0c;我采用将首尾组合的方式组成一个数组元素&#xff1b; 首先判断原始数据长度的…

onnx 1.16 doc学习笔记四:python API-If和Scan

onnx作为一个通用格式&#xff0c;很少有中文教程&#xff0c;因此开一篇文章对onnx 1.16文档进行翻译与进一步解释&#xff0c; onnx 1.16官方文档&#xff1a;https://onnx.ai/onnx/intro/index.html](https://onnx.ai/onnx/intro/index.html)&#xff0c; 如果觉得有收获&am…

$attrs

一、概念 vue官网定义如下: 包含了父作用域中不作为 prop 被识别 (且获取) 的 attribute 绑定 (class 和 style 除外)。当一个组件没有声明任何 prop 时,这里会包含所有父作用域的绑定 (class 和 style 除外),并且可以通过v-bind="$attrs"传入内部组件——在创建…

【高德地图】Android高德地图控件交互详细介绍

&#x1f4d6;第5章 与地图控件交互 ✅控件交互&#x1f9ca;缩放按钮&#x1f9ca;指南针&#x1f9ca;定位按钮&#x1f9ca;地图Logo ✅手势交互&#x1f9ca;缩放手势&#x1f9ca;滑动手势&#x1f9ca;旋转手势&#x1f9ca;倾斜手势&#x1f9ca;指定屏幕中心点的手势操…

无线传感器网络简单介绍

&#xff08;本文为简单介绍&#xff0c;内容来源自网络&#xff09; 无线传感器网络&#xff08;Wireless Sensor Networks&#xff09;是一种创新的传感器网络架构&#xff0c;具有广泛的应用前景和潜力。与传统的有限传感器网络不同&#xff0c;无线传感器网络克服了节点数…

在苹果电脑MAC上安装Windows10(双系统安装的详细图文步骤教程)

在苹果电脑MAC上安装Windows10&#xff08;双系统安装的详细图文步骤教程&#xff09; 一、准备工作准备项1&#xff1a;U盘作为系统安装盘准备项2&#xff1a;您需要安装的系统镜像 二、启动转换助理步骤1&#xff1a;找到启动转换助理步骤2&#xff1a;启动转换助理步骤3&…

基于springboot+vue的安康旅游网站(前后端分离)

博主主页&#xff1a;猫头鹰源码 博主简介&#xff1a;Java领域优质创作者、CSDN博客专家、阿里云专家博主、公司架构师、全网粉丝5万、专注Java技术领域和毕业设计项目实战&#xff0c;欢迎高校老师\讲师\同行交流合作 ​主要内容&#xff1a;毕业设计(Javaweb项目|小程序|Pyt…

【Java EE初阶二十】http的简单理解(一)

1. 初识http HTTP 最新的版本应该是 HTTP/3.0&#xff0c;目前大规模使用的版本 HTTP/1.1&#xff1b; 下面来简单说明一下使用 HTTP 协议的场景: 1、浏览器打开网站 (基本上) 2、手机 APP 访问对应的服务器 (大概率) 前面的 TCP与UDP 和http不同&#xff0c;HTTP 的报文格式&a…

基于Embedding召回和DSSM双塔模型

文章目录 基于Embedding召回介绍基于Embedding召回算法分类I2I召回U2I召回 DSSM模型DSSM双塔模型层次 基于Embedding召回介绍 基于embedding的召回是从内容文本信息和用户查询的角度出发&#xff0c;利用预训练的词向量模型或深度学习模型&#xff0c;将文本信息转换成向量进行…

【PyQt】15-让控件支持拖拽工作

文章目录 前言一、控件的拖拽-setAcceptDrops()1.1 代码1.2 运行结果 总结 前言 允许控件的拖拽操作&#xff0c;后续可以升级为拖拽图片之类的。hasHtml()、hasUrls()、hasImage() 一、控件的拖拽-setAcceptDrops() 比如把A放到B&#xff0c;需要两步 B—setAcceptDrops(Tru…

Hudi程序导致集群RPC偏高问题分析

1、背景 Hudi程序中upsert操作频繁&#xff0c;过多的删除和回滚操作,导致集群RPC持续偏高 2、描述 hudi采用的是mvcc设计&#xff0c;提供了清理工具cleaner来把旧版本的文件分片删除&#xff0c;默认开启了清理功能&#xff0c;可以防止文件系统的存储空间和文件数量的无限…

【自然语言处理】:实验5,司法阅读理解

清华大学驭风计划课程链接 学堂在线 - 精品在线课程学习平台 (xuetangx.com) 代码和报告均为本人自己实现&#xff08;实验满分&#xff09;&#xff0c;只展示主要任务实验结果&#xff0c;如果需要详细的实验报告或者代码可以私聊博主 有任何疑问或者问题&#xff0c;也欢…