Web前端—移动Web第一天(平面转换、渐变、综合案例--播客网页设计)

版本说明

当前版本号[20231117]。

版本修改说明
20231117初版

目录

文章目录

  • 版本说明
  • 目录
  • 移动 Web 第一天
    • 01-平面转换
      • 简介
        • 示例
      • 平移
      • 定位居中
      • 案例-双开门
      • 旋转
      • 转换原点
      • 案例-时钟
      • 多重转换
      • 缩放
      • 案例-播放特效
      • 倾斜
    • 02-渐变
      • 线性渐变
      • 案例-产品展示
      • 径向渐变
    • 03-综合案例
      • 导航-频道
        • 箭头旋转
        • 频道列表
      • 渐变按钮
        • 搜索按钮
        • 登录按钮
        • 客户端按钮
      • 轮播图
      • 猜你喜欢

移动 Web 第一天

目标:使用位移、缩放、旋转、渐变效果丰富网页元素的呈现方式。

01-平面转换

简介

作用:为元素添加动态效果,一般与过渡配合使用

概念:改变盒子在平面内的形态(位移、旋转、缩放、倾斜)

1681357773327

平面转换也叫 2D 转换,属性是 transform

示例

1、首先建个div盒子。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>平面转换</title><style>div{margin: 100px 0;width: 100px;height: 100px;background-color: pink;}</style></head><body><div></div></body>
</html>

image-20231116092947884

2、设置元素的过渡效果。

transition: all 1s;
/* 鼠标滑过,来添加动态效果 */div:hover{transform: translate(800px);}

丝滑地滑了过去。

image-20231116093159171

3、边转边移动。

/* 鼠标滑过,来添加动态效果 */div:hover{transform: translate(800px) rotate(360deg);}

image-20231116093310970

4、使图形比之前的大了一圈。

/* 鼠标滑过,来添加动态效果 */div:hover{transform: translate(800px) rotate(360deg) scale(2);}

image-20231116093409821

5、鼠标滑过,来添加动态效果。

/* 鼠标滑过,来添加动态效果 */div:hover{transform: translate(800px) rotate(360deg) scale(2) skew(180deg);}

image-20231116093520421

平移

transform: translate(X轴移动距离, Y轴移动距离);
  • 取值
    • 像素单位数值
    • 百分比(参照盒子自身尺寸计算结果)
    • 正负均可
  • 技巧
    • translate() 只写一个值,表示沿着 X 轴移动
    • 单独设置 X 或 Y 轴移动距离:translateX() 或 translateY()

定位居中

  • 方法一:margin

1681358064880

  • 方法二:平移 → 百分比参照盒子自身尺寸计算结果

1681358076134

1、建立个box模型。

<style>.box{width: 200px;height: 100px;background-color: pink;}</style>

image-20231116094524353

2、一个个去尝试。

<style>.box{position: absolute;/* 设置边偏移 *//* 将元素的左边距设置为其父元素的宽度的一半,即水平居中。 */left: 50%;/* 将元素的上边距设置为其父元素的高度的一半,即垂直居中。 */top: 50%;/* 将元素在水平和垂直方向上分别平移其自身宽度和高度的一半,以实现完全居中的效果。 *//* 即:往左往上挪字体宽度、高度的一半 */transform: translate(-50%, -50%);width: 200px;height: 100px;background-color: pink;}</style>

image-20231116094547544

案例-双开门

1681358110583

  • HTML 结构
<div class="father"><div class="left"></div><div class="right"></div>
</div>
  • CSS 样式
* {margin: 0;padding: 0;
}/* 1. 布局:父子结构,父级是大图,子级是左右小图 */
.father {display: flex;margin: 0 auto;width: 1366px;height: 600px;background-image: url(./images/bg.jpg);overflow: hidden;
}.father .left,
.father .right {width: 50%;height: 600px;background-image: url(./images/fm.jpg);transition: all .5s;
}.father .right {/* right 表示的取到精灵图右面的图片 */background-position: right 0;
}/* 2. 鼠标悬停的效果:左右移动 */
.father:hover .left {transform: translate(-100%);
}.father:hover .right {transform: translateX(100%);
}

1、首先初步建立个模型。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>双开门</title><style>*{margin: 0;padding: 0;}/* 布局:父子结构,父级是大图,子级是左右小图 */.father{margin: 0 auto;width: 1366px;height: 600px;background-image: url(../img/bg.jpg);}</style></head><body><div class="father"></div></body>
</html>

image-20231116104514365

2、把左、右两图给设置好。

<body><div class="father"><div class="left">1</div><div class="right">2</div></div></body>
.father .left,.father .right{width: 50%;height: 600px;background-image: url(../img/fm.jpg);}

image-20231116104831804

3、接下来要把右边的精灵图换个位置。

.father .right{background-position: right 0; }

image-20231116105042056

4、开始移动。

/* 鼠标悬停效果:左右移动 */.father:hover .left{transform: translate(-100%);}.father:hover .right{transform: translateX(100%);}

image-20231116105514374

5、设置慢慢移动。

.father .left,.father .right{width: 50%;height: 600px;background-image: url(../img/fm.jpg);transition: all 0.5s;}

6、多余的隐藏起来,实现效果。

.father{display: flex;margin: 0 auto;width: 1366px;height: 600px;background-image: url(../img/bg.jpg);overflow: hidden;}

image-20231116105717904

旋转

transform: rotate(旋转角度);
  • 取值:角度单位是 deg
  • 技巧
    • 取值正负均可
    • 取值为顺时针旋转
    • 取值为逆时针旋转

转换原点

默认情况下,转换原点是盒子中心点

transform-origin: 水平原点位置 垂直原点位置;

取值:

  • 方位名词(left、top、right、bottom、center)
  • 像素单位数值
  • 百分比

1、首先先做出来一个。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>转换原点</title><style>img{width: 200px;border: 1px solid #000;transition: all 2s;}img:hover{transform: rotate(360deg);}</style></head><body><img src="../img/rotate.png" alt=""></body>
</html>

image-20231116110529235

2、然后以右下角的原点进行旋转。

transform-origin: right bottom;

image-20231116110645937

案例-时钟

先加旋转,当发现旋转没有到位的时候,我们再加transform进行调整

1681358351628

css样式:

.hour {width: 6px;height: 50px;background-color: #333;margin-left: -3px;transform: rotate(15deg);transform-origin: center bottom;
}.minute {width: 5px;height: 65px;background-color: #333;margin-left: -3px;transform: rotate(90deg);transform-origin: center bottom;
}.second {width: 4px;height: 80px;background-color: red;margin-left: -2px;transform: rotate(240deg);transform-origin: center bottom;
}

多重转换

多重转换技巧:先平移再旋转

transform: translate() rotate();
  • 多重转换原理:以第一种转换方式坐标轴为准转换形态
    • 旋转会改变网页元素的坐标轴向
    • 先写旋转,则后面的转换效果的轴向以旋转后的轴向为准,会影响转换结果

1、先把轮胎与背后的框先画出来。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>多重效果</title><style>.box{width: 800px;height: 200px;border: 1px solid #000;}img{width: 200px;transition: all 5s;}</style></head><body><div class="box"><img src="../img/tyre.png" alt=""></div></body>
</html>

image-20231116115027094

2、对轮胎进行滚动设置。

/* 鼠标滑动,图片开始滚动 */.box:hover img{/* 先平移在旋转 */transform:translate(600px) rotate(360deg);}

image-20231116115538782

image-20231116115554942

缩放

transform: scale(缩放倍数);
transform: scale(X轴缩放倍数, Y轴缩放倍数);
  • 技巧
    • 通常,只为 scale() 设置一个值,表示 X 轴和 Y 轴等比例缩放
    • 取值大于1表示放大,取值小于1表示缩小

如:

transform: scale(1); //没有任何效果
transform: scale(2); //放大
transform: scale(0.5); //缩小

案例-播放特效

1681358481436

  • CSS 样式
/* 1. 摆放播放按钮:图片区域的中间 */
.box li {overflow: hidden;
}.pic {position: relative;
}.pic::after {position: absolute;left: 50%;top: 50%;/* margin-left: -29px;margin-top: -29px; *//* transform: translate(-50%, -50%); */content: '';width: 58px;height: 58px;background-image: url(./images/play.png);transform: translate(-50%, -50%) scale(5);opacity: 0;transition: all .5s;
}
/* 2. hover效果:大按钮,看不见:透明是0 → 小按钮,看得见:透明度1 */
.box li:hover .pic::after {transform: translate(-50%, -50%) scale(1);opacity: 1;
}

1、建立雏形。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>按钮缩放</title><style>* {margin: 0;padding: 0;}li {list-style: none;}img{width: 100%;}.box{width: 249px;height: 210px;margin: 50px auto;}.box p{color: #3b3b3b;padding: 10px 10px 0 10px;}</style></head><body><div class="box"><ul><li><div class="pic"><img src="../img/party.jpg" alt=""></div><p>【和平精英:“初火”音乐概念片:四圣觉醒......】</p></li></ul></div></body>
</html>

image-20231116142837341

2、放置播放按钮。

.pic{position: relative;}/* 1.摆放播放按钮:图片区域的中间 */.pic::after{position: absolute;content: '';width: 58px;height: 58px;background-image: url(../img/play.png);}

image-20231116143359886

3、把其放置中间。

/* 1.摆放播放按钮:图片区域的中间 */.pic::after{position: absolute;left: 50%;top: 50%;margin-left: -29px;margin-top: -29px;content: '';width: 58px;height: 58px;background-image: url(../img/play.png);}

image-20231116143546498

4、生成缩放效果。

/* 1.摆放播放按钮:图片区域的中间 */.pic::after{position: absolute;left: 50%;top: 50%;margin-left: -29px;margin-top: -29px;content: '';width: 58px;height: 58px;background-image: url(../img/play.png);transform: scale(5);opacity: 0;transition: all 0.5s;}/* 2、hover效果:大按钮,看不见;透明是0 -> 小按钮,看得见;透明度1 */.box li:hover .pic::after{transform: scale(1);opacity: 1;}

image-20231116144118062

5、超出li标签 的部分隐藏一下,就完成了。

.box li{overflow: hidden;}

注:如果一段css样式中有多条 transform ,就会出现重叠的现象。后面会生效,前面会失效。

解决方法:把所有关于 transform 的语句合在同一句里。

image-20231116144542167

倾斜

transform: skew();

取值:角度度数 deg

1、transform: skew(30deg);效果:

div:hover{transform: skew(30deg);}

image-20231116145430720

2、transform: skew(-30deg);效果:

div:hover{transform: skew(-30deg);}

image-20231116145520648

02-渐变

渐变是多个颜色逐渐变化的效果,一般用于设置盒子背景

分类:

  • 线性渐变

1681358603090

  • 径向渐变

1681358608036

线性渐变

background-image: linear-gradient(渐变方向,颜色1 终点位置,颜色2 终点位置,......
);

取值:

  • 渐变方向:可选
    • to 方位名词
    • 角度度数
  • 终点位置:可选
    • 百分比

1、从 skyblue 到 yellow 的渐变。

<!DOCTYPE html>
<html><head><meta charset="utf-8"><title>渐变</title><style>div{width: 200px;height: 200px;background-color: skyblue;background-image: linear-gradient(skyblue,yellow);}</style></head><body><div></div></body>
</html>

image-20231116150531492

2、从 skyblue 到 yellow ,方向向右的渐变。

background-image: linear-gradient(to right,skyblue,yellow);

image-20231116150605028

3、从 skyblue 到 yellow 的渐变,其中 skyblue 占70%。

background-image: linear-gradient(skyblue 70%,yellow);

image-20231116150724543

案例-产品展示

1681358757636

  • HTML 结构
<div class="box"><img src="./images/product.jpeg" alt="" /><div class="title">OceanStor Pacific 海量存储斩获2021 Interop金奖</div><div class="mask"></div>
</div>
  • CSS 样式
.mask {position: absolute;left: 0;top: 0;width: 100%;height: 100%;background-image: linear-gradient(transparent,rgba(0,0,0,0.5));opacity: 0;transition: all .5s;
}.box:hover .mask {opacity: 1;
}

径向渐变

给按钮添加高光效果

background-image: radial-gradient(半径 at 圆心位置,颜色1 终点位置,颜色2 终点位置,......
);

取值:

  • 半径可以是2条,则为椭圆
  • 圆心位置取值:像素单位数值 / 百分比 / 方位名词

1、左、右中心的大小为50px的圆心,从 blue 到 skyblue 的渐变。

background-image: radial-gradient(50px at center center,blue,skyblue);

image-20231116152408756

03-综合案例

1681365549936

导航-频道

箭头旋转
.x-header-nav .nav-item:hover .icon-down {transform: rotate(-180deg);
}

image-20231116202232585

频道列表
.channel-layer {position: absolute;top: 60px;left: 50%;z-index: -2;width: 1080px;height: 120px;padding: 10px;margin-left: -540px;color: #72727b;background-color: #f5f5f5;border: 1px solid #e4e4e4;border-top: none;transition: all 0.5s;transform: translateY(-120px);
}/* TODO 2. 弹窗频道 */
.x-header-nav .nav-item:hover .channel-layer {transform: translateY(0);
}

image-20231116202513776

渐变按钮

搜索按钮
.x-header-search form .btn {position: absolute;top: 0;right: 0;width: 60px;height: 40px;line-height: 40px;text-align: center;background-color: #f86442;border-top-right-radius: 20px;border-bottom-right-radius: 20px;background-image: linear-gradient(to right,rgba(255, 255, 255, 0.3),#f86442);
}
登录按钮
/* TODO 7. 渐变按钮 */
.card .card-info .login {padding: 3px 34px;color: #fff;background-color: #ff7251;border-radius: 30px;box-shadow: 0 4px 8px 0 rgb(252 88 50 / 50%);background-image: linear-gradient(to right,rgba(255, 255, 255, 0.2),#ff7251);
}
客户端按钮
/* TODO 8. 径向渐变 */
.download .dl .dl-btn {width: 68px;height: 34px;line-height: 34px;color: #fff;text-align: center;border-radius: 4px;background-image: radial-gradient(50px at 10px 10px,rgba(255, 255, 255, 0.5),transparent);
}

轮播图

/* TODO 4. 摆放图片 */
.banner .banner-list .banner-item.left {z-index: 0;transform: translate(-160px) scale(0.8);transform-origin: left center;
}.banner .banner-list .banner-item.right {z-index: 0;transform: translate(160px) scale(0.8);transform-origin: right center;
}

猜你喜欢

/* TODO 5. 播放按钮和遮罩 */
.album-item .album-item-box::after {position: absolute;left: 0;top: 0;content: '';width: 100%;height: 100%;background: rgba(0,0,0,.5) url(../assets/play.png) no-repeat center / 20px;opacity: 0;transition: all .5s;
}.album-item .album-item-box:hover::after {opacity: 1;background-size: 50px;
}/* TODO 6. 图片缩放 */
.album-item .album-item-box:hover img {transform: scale(1.1);
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

学人工智能等于失业?

随着科技的快速发展&#xff0c;人工智能已经渗透到我们生活的方方面面&#xff0c;从手机、智能家居到自动驾驶汽车&#xff0c;都离不开人工智能技术的支持。 因此&#xff0c;学习人工智能已经成为越来越多人追求高薪职业的选择。在这篇文章中&#xff0c;我们将探讨学习人…

asp.net core mvc之 过滤器

过滤器允许我们在Action执行之前和执行之后去执行一下业务代码 一、过滤器的作用域 1、全局过滤器&#xff0c; 在Startup.cs文件中注册 2、控制器过滤器&#xff0c; 在控制器类上面使用标注 3、action过滤器 二、全局过滤器使用 1、在 core 目录&#xff0c;添加 TestA…

Linux系统下安装go

目录 下载go安装包解压包并安装添加环境变量验证是否安装成功 下载go安装包 官网地址&#xff1a;go 解压包并安装 复制好包的下载链接后使用下面命令进行安装&#xff1a; curl -O https://storage.googleapis.com/golang/go1.11.1.linux-amd64.tar.gz mkdir -p ~/installe…

论文学习——THE USTC SYSTEM FOR ADRESS-M CHALLENGE

文章目录 引言正文Abstract模型基本结构模型效果汇总 Introduction介绍跨语言任务的独特性思路启发和变化如何使用预定义好的音频特征如何使用预定义好的语言模型——语言模型中获取韵律信息结果说明 Dataset数据集Mthods方法使用设计好的特征进行AD检测使用的特征分类和训练方…

【人工智能】本地运行开源项目MMSegmentation引发的问题

文章目录 ❌AssertionError: Torch not compiled with CUDA enabled问题描述问题分析解决方案总结参考文献 ❌AssertionError: Torch not compiled with CUDA enabled 问题描述 python demo/image_demo.py demo/demo.png configs/pspnet/pspnet_r50-d8_4xb2-40k_cityscapes-5…

MySQL主主复制

主1 192.168.66.15 主2 192.168.66.16 主1&#xff1a; roottest2 ~]# hostname master1 [roottest2 ~]# bash [rootmaster1 ~]# vim /etc/my.cnf server-id11 log-binmysql-bin auto_increment_increment2 auto_increment_offset1 replicate-do-dbdemo_db …

android初集成flutter,遇到的问题

环境 studio版本&#xff1a;2022.1.1 flutter版本&#xff1a;2.8.0 电脑&#xff1a;mac flutter项目总是报错&#xff0c;编译不过 以 Resources Root 加载 记得设置dart&#xff1a;主工程和flutter项目都需要设置&#xff0c;否则不出现手机链接 下面这个样子就是好了&…

腾讯云服务器新用户购买优惠多少钱?腾讯云新用户优惠信息来了!

腾讯云服务器新用户购买优惠多少钱&#xff1f;这是每个新手上路的人都会问到的问题。 如果你是一个刚刚接触云服务器的小白用户&#xff0c;不知道该如何选择合适的云服务器&#xff0c;那么你就来对了地方。今天我们将向你介绍腾讯云服务器新用户购买优惠活动&#xff0c;让…

ubuntu 20.04+ORB_SLAM3 安装配库教程

目录 安装ros(如果只是运行ORB-SLAM3&#xff0c;可以跳过安装)0. ros 安装教程1. 安装opencv2. 安装Pangolin3. 安装Eigen34.安装Python & libssl-dev5.安装boost库6.安装ceres库&#xff08;不必须&#xff09;7.安装Sophus库&#xff08;不必须&#xff09;8. 安装g20库…

jQuery UI简单的讲解

我们先进入一下问答时间&#xff0c;你都知道多少呢&#xff1f; &#xff08;1&#xff09;什么是jQuery UI 呢&#xff1f; 解答&#xff1a;jQuery UI 是以 jQuery 为基础的开源 JavaScript 网页用户界面代码库。包含底层用户交互、动画、特效和可更换主题的可视控件。我们…

Ubuntu 下C++数字雨

以前写过一个Window下的数字雨&#xff0c;像黑客帝国里那样的01数字&#xff0c;现在补充一版Linux下的。使用了curses库&#xff0c;安装方法与使用方法参照 Linux下curses函数库的详细介绍_libcurses库-CSDN博客 5-linux学习笔记之-----curses-CSDN博客 效果如下&#xf…

ERR_PNPM_INVALID_WORKSPACE_CONFIGURATION packages field missing or empty

vue执行 pnpm install命令时&#xff0c;报 ERR_PNPM_INVALID_WORKSPACE_CONFIGURATION  packages field missing or empty错&#xff0c;在网上查询了很久&#xff0c;也没有传出来结果&#xff0c;最后发现是pnpm的版本不对引起的。 我先执行的是npm install -g pnpm&…

实例解释遇到前端报错时如何排查问题

前端页面报错&#xff1a; 1、页面报错500&#xff0c;首先我们可以知道是服务端的问题&#xff0c;需要去看下服务端的报错信息&#xff1a; 2、首先我们查看下前端是否给后端传了id: 我们可以看到接口是把ID返回了&#xff0c;就需要再看下p_id是什么情况了。 3、我们再次请…

数字艺术藏品软件的独特创新与未来趋势

随着科技的飞速发展&#xff0c;数字艺术藏品软件逐渐崭露头角&#xff0c;为艺术爱好者们提供了一个全新的收藏方式。这类软件不仅为艺术家提供了展示作品的平台&#xff0c;也为收藏家们提供了收藏和分享艺术品的渠道。本文将从开发思路、技术实现、市场前景等方面探讨数字艺…

Postman批量运行用例

近期在复习Postman的基础知识&#xff0c;在小破站上跟着百里老师系统复习了一遍&#xff0c;也做了一些笔记&#xff0c;希望可以给大家一点点启发。 一&#xff09;注意点 有上传文件的接口&#xff0c;需要做如下设置&#xff1a; 1、打开能读取外部文件的开关 2、把需要…

2023数字科技生态大会-数字安全论坛 学习笔记

监管合规->价值创造的方向&#xff0c;在安全领域的发展方向-安全运营服务型 ICT->数字->数据 数字安全&#xff1a;网络安全数据安全 传统信息化以计算为核心&#xff0c;数字化以数据为核心 数字安全技术发展十大趋势&#xff1a; 一、 数字安全技术政策环境将不…

HarmonyOS 实战项目

引言 本章将介绍如何在 HarmonyOS 上进行实际项目开发。我们将从项目需求分析开始&#xff0c;逐步完成项目的设计、开发、测试和上线过程。 1. 项目需求分析 项目需求分析是项目开发的关键阶段之一&#xff0c;它有助于确定项目的范围、目标和功能&#xff0c;为项目的设计和开…

【Android】画面卡顿优化列表流畅度四之Glide几个常用参数设置

好像是一年前快两年了&#xff0c;笔者解析过glide的源码&#xff0c;也是因为觉得自己熟悉一些&#xff0c;也就没太关注过项目里glide的具体使用对当前业务的影响&#xff1b;主要是自负&#xff0c;还有就是真没有碰到过这样的数据加载情况。暴露了经验还是不太足够 有兴趣的…

在线协作工具都有哪些?推荐这10款

如今&#xff0c;互联网的快速发展不仅改变了我们的生活方式&#xff0c;也改变了我们的工作方式。 特别是对于一些与产品设计相关的公司或团体&#xff0c;网络不仅为其设计提供了稳定的资源和灵感&#xff0c;而且为成员之间的沟通和合作提供了更大的便利。 如果您也需要为…

ke11介绍本地,会话存储

代码顺序: 1.设置input,捕获input如果有多个用属性选择符例如 input[typefile]点击事件.向我们的本地存储设置键值对 2.在点击事件外面设置本地存储表示初始化的值.点击上面的事件才能修改我们想修改的值 会话(session)浏览a数据可以写到本地硬盘,关闭页面数据就没了 本地(…