Web进阶:Day3 移动端特点、百分比布局、Flex布局、实战演练

简介: Web进阶:Day3 移动端特点、百分比布局、Flex布局、实战演练

Web进阶:Day3

Date: January 7, 2023

Summary: 移动端特点、百分比布局、Flex布局、实战演练


移动端特点

移动端和PC端网页不同点

PC端网页和移动端网页的有什么不同?


PC屏幕大,网页固定版心


手机屏幕小, 网页宽度多数为100%


谷歌模拟器

如何在电脑里面边写代码边调试移动端网页效果?


谷歌模拟器

89ec64c49cfae656422d6893df459408.png

分辨率

目标:了解屏幕尺寸概念概念


屏幕尺寸


指的是屏幕对角线的长度,一般用英寸来度量

54b489349add31f2e1026638234d592b.png



目标:了解移动端主流设备分辨率


PC分辨率


1920 * 1080


1366 * 768


……


缩放150%


(1920/150%)*(1080/150%)

1f7bcfd83f78349e0e1528c65a25dec8.png

总结


硬件分辨率(出厂设置)


缩放调节的分辨率(软件设置)


目标:了解移动端主流设备分辨率


分辨率分类


物理分辨率是生产屏幕时就固定的,它是不可被改变的


逻辑分辨率是由软件(驱动)决定的

0284feccf3ad69efc346d18e15c802a3.png

思考:制作网页参考物理分辨率还是逻辑分辨率?


逻辑分辨率

369ca18acb751c8fb188c1cf30711076.png

7ac6f0e017eace23f20215c4ea4b010a.png

注意:我们参考iPhone6/7/8手机型号,进行书写代码


视口

目标:使用meta标签设置视口宽度,制作适配不同设备宽度的网页

7a8c54f20679417a6081be5878162be7.png

手机屏幕尺寸都不同, 网页宽度为100%, 网页的宽度和逻辑分辨率尺寸相同。

198f7949c3b7c5b048c4d88b9df41d7b.png

思考:默认情况下,网页的宽度和逻辑分辨率相同吗?


不同, 默认网页宽度是980px。

e65d1fb85b63dbc899fdb4b8ad55c896.png

目标:网页宽度和设备宽度(分辨率)相同。


解决办法:添加视口标签。


视口:显示HTML网页的区域,用来约束HTML尺寸。

<meta name="viewport" content="width=device-width, initial-scale=1.0">

viewport:视口


width=device-width:视口宽度 = 设备宽度


initial-scale=1.0:缩放1倍(不缩放)


二倍图

目标:能够使用像素大厨软件测量二倍图中元素的尺寸

210e2998b30774e71b9c8a9151c6fb29.png

图片分辨率, 为了高分辨率下图片不会模糊失真


现阶段设计稿参考iPhone6/7/8,设备宽度375px产出设计稿。


二倍图设计稿尺寸:750px。

98103cbe9d4136e8207d5a969a943469.png

总结:


二倍图的作用:让图片更清晰一些


二倍图在像素大厨中如何操作:设计图中选择2x,再去量尺寸


我们要给基于375px(即逻辑分辨率去书写代码),如果是750px,量出的尺寸都是二倍,到时候网页盛不下


百分比布局

目标: 能够使用百分比布局开发网页


百分比布局, 也叫流式布局


效果: 宽度自适应,高度固定

e50b3419533898a8905c965d5753ab75.png

案例:


Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>京东</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        li {
            list-style: none;
        }
        .toolbar {
            position: fixed;
            left: 0;
            bottom: 0;
            /* 百分比布局  流式布局 */
            width: 100%;
            height: 50px;
            background-color: pink;
            border-top: 1px solid #ccc;
        }
        .toolbar li img {
            height: 100%;
        }
        .toolbar li {
            float: left;
            width: 20%;
            height: 50px;
        }
    </style>
</head>
<body>
    <div class="toolbar">
        <ul>
            <li>
                <a href="#"><img src="./images/index.png" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/classify.png" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/jd.png" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/car.png" alt=""></a>
            </li>
            <li>
                <a href="#"><img src="./images/login.png" alt=""></a>
            </li>
        </ul>
    </div>
</body>
</html>

注意:这是较老的解决方案,现在宽高都会自适应


Flex布局

Flex布局模型构成

目标: 能够使用Flex布局模型灵活、快速的开发网页

思考:


多个盒子横向排列使用什么属性?


浮动


设置盒子间的间距使用什么属性?


margin


需要注意什么问题?


浮动的盒子脱标(父级不设置高度会产生这种情况)

983be3fcd48bf2d746d8a173c6670892.png

Flex布局/弹性布局:


是一种浏览器提倡的布局模型


布局网页更简单、灵活


避免浮动脱标的问题


注意1:浮动原本是为了解决文字环绕问题的,而Flex是专门为了解决网页布局问题的


注意2:Flex可能不支持低版本的浏览器


作用:


基于 Flex 精确灵活控制块级盒子的布局方式,避免浮动布局中脱离文档流现象发生。


Flex布局非常适合结构化布局


设置方式:


父元素添加 display: flex,子元素可以自动的挤压或拉伸


注意:必须是直接父元素,不可以是父元素的父元素


组成部分:


弹性容器:最大的父级


弹性盒子:子集


主轴:横着的轴默认是主轴


侧轴 / 交叉轴:竖着的轴默认是侧轴

eaae0b7a15e440186c5c95be9406f6ad.png

案例:

da87f6d633ace6d297c81a1d476382d1.png

Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>体验flex布局</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            /* 视觉效果: 子级一行排列/水平排列 */
            /* 水平排列: 默认主轴在水平, 弹性盒子都是沿着主轴排列 */
            display: flex;
            height: 200px;
            border: 1px solid #000;
        }
        .box div {
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
</head>
<body>
    <div class="box">
        <div>1</div>
        <div>2</div>
        <div>3</div>
    </div>
</body>
</html>

主轴对齐方式

目标:使用justify-content调节元素在主轴的对齐方式

思考:网页中,盒子之间有距离吗?


答:有。


在Flex布局模型中,调节主轴或侧轴的对齐方式来设置盒子之间的间距。

2dfd91d94969840a287c402bbd1985db.png

修改主轴对齐方式属性: justify-content

85980210bfd8fb15caa2be8716c6ac7d.png

修改主轴对齐方式属性: justify-content

75a42ddf37ffaf43968dcff343ef4fc8.png

案例:


Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>主轴对齐方式</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            display: flex;
            /* 居中 */
            justify-content: center;
            /* 间距在弹性盒子(子级)之间 */
            justify-content: space-between;
            /* 所有地方的间距都相等 */
            justify-content: space-evenly;
            /* 间距加在子级的两侧 */
            /* 视觉效果: 子级之间的距离是父级两头距离的2倍 */
            justify-content: space-around;
            height: 200px;
            margin: auto;
            border: 1px solid #000;
        }
        .box div {
            width: 100px;
            height: 100px;
            background-color: pink;
        }
    </style>
</head>
<body>
    <div class="box">
        <div>1</div>
        <div>2</div>
        <div>3</div>
    </div>
</body>
</html>

侧轴对齐方式

目标:使用align-items调节元素在侧轴的对齐方式

5ef1015225cb73a23252c42e173d9cd5.png

修改侧轴对齐方式属性:

align-items(添加到弹性容器)


align-self: 控制某个弹性盒子在侧轴的对齐方式(添加到弹性盒子)

aa8d9d4d9ffddde553ffe963bdabc7dc.png

案例:

61041d769ba453378ac5c87626892883.png

Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>侧轴对齐方式</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            display: flex;
            /* 居中 */
            /* align-items: center; */
            /* 拉伸,默认值(现有状态,测试的时候去掉子级的高度) */
            /* align-items: stretch; */
            height: 300px;
            margin: auto;
            border: 1px solid #000;
        }
        .box div {
            /* 没有宽度的话,盒子的宽度为内容的宽度 */
            /* width: 100px; */
            /* height: 100px; */
            background-color: pink;
        }
        /* 单独设置某个弹性盒子的侧轴对齐方式 */
        .box div:nth-child(2) {
            align-self: center;
        }
    </style>
</head>
<body>
    <div class="box">
        <div>1111</div>
        <div>2</div>
        <div>3</div>
    </div>
</body>
</html>

伸缩比

目标:使用flex属性修改弹性盒子伸缩比


属性


flex : 值;


取值分类


数值(整数)

51de050e461e2b32b0f4ee4e24a3712e.png

注意 : 只占用父盒子剩余尺寸


案例:

4f6a142ce66f2a73f5374d88986ed100.png

Code:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        .box {
            display: flex;
            height: 300px;
            border: 1px solid #000;
        }
        .box div {
            height: 200px;
            margin: 0 20px;
            background-color: pink;
        }
        .box div:nth-child(1) {
            width: 50px;
        }
        .box div:nth-child(2) {
            /* 占用父级剩余尺寸的份数 */
            flex: 3;
        }
        .box div:nth-child(3) {
            flex: 1;
        }
    </style>
</head>
<body>
    <div class="box">
        <div>1</div>
        <div>2</div>
        <div>3</div>
    </div>
</body>
</html>

实战演练-小兔鲜儿 - 确认订单

目标:使用Flex布局模型快速开发网页

75594c7d3faf3f23a5375d6db488a790.png

Code:


HTML

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>确认订单</title>
    <link rel="stylesheet" href="./lib/iconfont/iconfont.css">
    <link rel="stylesheet" href="./css/base.css">
    <link rel="stylesheet" href="./css/orders.css">
</head>
<body>
    <!-- 主体内容: 滑动查看 -->
    <div class="main">
        <!-- 用户信息 -->
        <div class="pannel user_msg">
            <div class="location">
                <i class="iconfont icon-location"></i>
            </div>
            <div class="user">
                <div class="top">
                    <h5>林丽</h5>
                    <p>18500667882</p>
                </div>
                <div class="bottom">北京市  海淀区  中关村软件园   信息科技大厦1号
                    楼410#   </div>
            </div>
            <div class="more">
                <i class="iconfont icon-more"></i>
            </div>
        </div>
        <!-- 用户信息 -->
    </div>
    <!-- 主体内容: 滑动查看 -->
    <!-- 底部支付: 固定定位 -->
    <div class="pay">
        <div class="left">
            合计: <span class="red">¥<i>266.00</i></span>
        </div>
        <div class="right">
            <a href="#">去支付</a>
        </div>
    </div>
    <!-- 底部支付: 固定定位 -->
</body>
</html>

CSS


orders.css

body {
    background-color: #f7f7f8;
}
/* 公共样式 */
.red {
    color: #cf4444;
}
.pannel {
    margin-bottom: 10px;
    background-color: #fff;
    border-radius: 5px;
}
/* 主体内容 */
.main {
    /* 80px: 为了内容不被底部区域盖住 */
    padding: 12px 11px 80px;
}
/* 用户信息 */
.user_msg {
    display: flex;
    align-items: center;
    padding: 15px 0 15px 11px;
}
.user_msg .location {
    width: 30px;
    height: 30px;
    margin-right: 10px;
    background-image: linear-gradient(90deg, 
    #6fc2aa 5%, 
    #54b196 100%);
    border-radius: 50%;
    text-align: center;
    line-height: 30px;
    color: #fff;
}
.user_msg .user {
    flex: 1;
}
.user_msg .user .top {
    display: flex;
}
.user_msg .user .top h5 {
    width: 55px;
    font-size: 15px;
    font-weight: 400;
}
.user_msg .user .top p {
    font-size: 13px;
}
.user_msg .user .bottom {
    margin-top: 5px;
    font-size: 12px;
}
.user_msg .more {
    width: 44px;
    height: 44px;
    /* background-color: pink; */
    text-align: center;
    line-height: 44px;
    color: #808080;
}
/* 主体内容 */
/* 底部支付 */
.pay {
    position: fixed;
    left: 0;
    bottom: 0;
    display: flex;
    /* 主轴对齐方式 */
    justify-content: space-between;
    /* 侧轴对齐方式 */
    align-items: center;
    width: 100%;
    height: 80px;
    padding: 0 11px;
    /* background-color: pink; */
    border-top: 1px solid #ededed;
}
.pay .left {
    font-size: 12px;
}
.pay .left i {
    font-size: 20px;
}
.pay .right a {
    display: block;
    width: 90px;
    height: 35px;
    background-image: linear-gradient(90deg, 
    #6fc2aa 5%, 
    #54b196 100%);
    border-radius: 3px;
    text-align: center;
    line-height: 35px;
    font-size: 13px;
    color: #fff;
}
/* 底部支付 */

base.css

* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}
body {
  font: 16px/1.5 sans-serif;
  color: #333;
  background-color: #fff;
}
li {
  list-style: none;
}
em,
i {
  font-style: normal;
}
a {
  text-decoration: none;
  color: #333;
}
a:hover {
  color: #5eb69c;
}
img {
  width: 100%;
  vertical-align: middle;
}
input {
  padding: 0;
  border: none;
  outline: none;
  color: #333;
}
button {
  cursor: pointer;
}
/* 清除浮动 */
.clearfix:before,
.clearfix:after {
  content: '';
  display: table;
}
.clearfix:after {
  clear: both;
}
.clearfix {
  *zoom: 1;
}


相关文章
|
6月前
|
前端开发 算法 Java
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
(CSS)使用Flex布局,帮助你快速了解各种基本的Flex布局属性以及帮你让元素快速达到布局中的指定位置!
211 1
|
6月前
|
前端开发 算法 Java
【CSS】前端三大件之一,如何学好?从基本用法开始吧!(六):全方面分析css的Flex布局,从纵、横两个坐标开始进行居中、两端等元素分布模式;刨析元素间隔、排序模式等
Flex 布局 布局的传统解决方案,基于盒状模型,依赖 display 属性 + position属性 + float属性。它对于那些特殊布局非常不方便,比如,垂直居中就不容易实现。 2009年,W3C 提出了一种新的方案----Flex 布局,可以简便、完整、响应式地实现各种页面布局。目前,它已经得到了所有浏览器的支持,这意味着,现在就能很安全地使用这项功能。 一、Flex 布局是什么? Flex 是 Flexible Box 的缩写,意为"弹性布局",用来为盒状模型提供最大的灵活性。
437 0
|
7月前
|
存储 前端开发 Java
【JAVA】Java 项目实战之 Java Web 在线商城项目开发实战指南
本文介绍基于Java Web的在线商城技术方案与实现,涵盖三层架构设计、MySQL数据库建模及核心功能开发。通过Spring MVC + MyBatis + Thymeleaf实现商品展示、购物车等模块,提供完整代码示例,助力掌握Java Web项目实战技能。(238字)
838 0
|
10月前
|
设计模式 容器
13.HarmonyOS流式卡片列表实现指南:Flex多行布局详解
在现代移动应用开发中,流式卡片列表是一种常见且实用的UI设计模式。它能够自适应屏幕宽度,在有限空间内高效展示多个内容项。本教程将详细讲解如何使用HarmonyOS的ArkUI框架中的Flex组件实现一个灵活的流式卡片列表,重点关注多行布局与对齐策略的应用。
333 2
|
10月前
|
开发者 UED 容器
07.精通HarmonyOS Flex对齐:从基础到高级布局技巧(上)
在HarmonyOS Next的ArkUI框架中,Flex容器提供了强大而灵活的对齐系统,使开发者能够精确控制子元素在容器中的排列方式。掌握这些对齐技术,是构建专业级用户界面的关键。
299 0
|
10月前
|
UED 容器
5.HarmonyOS Next开发宝典:掌握Flex布局的艺术
Flex布局(弹性布局)是HarmonyOS Next中最强大的布局方式之一,它提供了一种更加高效、灵活的方式来对容器中的子元素进行排列、对齐和分配空间。无论是简单的居中显示,还是复杂的自适应界面,Flex布局都能轻松应对。
295 0
|
7月前
|
存储 JavaScript 安全
Web渗透-XSS漏洞深入及xss-labs靶场实战
XSS(跨站脚本攻击)是常见的Web安全漏洞,通过在网页中注入恶意脚本,窃取用户信息或执行非法操作。本文介绍其原理、分类(反射型、存储型、DOM型)、测试方法及xss-labs靶场实战案例,帮助理解与防御XSS攻击。
2351 1
Web渗透-XSS漏洞深入及xss-labs靶场实战
|
7月前
|
安全 Linux PHP
Web渗透-命令执行漏洞-及常见靶场检测实战
命令执行漏洞(RCE)指应用程序调用系统命令时,用户可控制输入参数,导致恶意命令被拼接执行,从而危害系统安全。常见于PHP的system、exec等函数。攻击者可通过命令连接符在目标系统上执行任意命令,造成数据泄露或服务瘫痪。漏洞成因包括代码层过滤不严、第三方组件缺陷等。可通过参数过滤、最小权限运行等方式防御。本文还介绍了绕过方式、靶场测试及复现过程。
1625 0
|
前端开发 API 开发者
给Web开发者的HarmonyOS指南02-布局样式
本系列教程适合鸿蒙 HarmonyOS 初学者,为那些熟悉用 HTML 与 CSS 语法的 Web 前端开发者准备的。
481 5
给Web开发者的HarmonyOS指南02-布局样式
|
开发者 容器
鸿蒙开发:弹性布局Flex
在实际的开发中,需要掌握主轴与交叉轴的关系、换行规则及子元素属性,同时注意性能与兼容性问题,还有一点,Flex组件在渲染时存在二次布局过程,因此在对性能有严格要求的场景下建议使用Column、Row代替。
335 10
鸿蒙开发:弹性布局Flex
下一篇
开通oss服务