iPhone SE切换颜色特效

Apple 网站的特效, iPhone SE 共有黑、白、红三种颜色,在卷动页面的时候会逐步替换,看起来效果非常时尚,在此供上代码学习。
<!DOCTYPE html>
<html>
<head>
<title>iPhone SE切换颜色特效</title>
<style type="text/css">
html {
font-size: 48px;
--iphone-black-bg: #000;
--iphone-black-text: #f2f2f2;
--iphone-white-bg: #fff;
--iphone-white-text: #8b8b99;
--iphone-white-text-highlight: #1d1d1f;
--iphone-red-bg: #960b19;
--iphone-red-text: #e57571;
--iphone-red-text-highlight: #f5f5f7;
--iphone-width: 460px;
--iphone-offscreen: -720px;
}
body {
margin: 0;
height: 4000px;
font-family: Helvetica;
background-color: #000;
}
.sticky-container {
position: sticky;
top: 0;
width: 100%;
height: 100vh;
overflow: hidden;
}
.sticky-container .iphone {
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
width: 100%;
height: 100vh;
position: absolute;
top: 0;
left: 0;
}
.sticky-container .iphone h3 {
font-size: 1rem;
margin: 0 0 60px 0;
width: var(--iphone-width);
}
.sticky-container .iphone img {
display: block;
width: var(--iphone-width);
margin-bottom: var(--iphone-offscreen);
}
.sticky-container .iphone.black {
background-color: var(--iphone-black-bg);
z-index: 10;
}
.sticky-container .iphone.black h3 {
color: var(--iphone-black-text);
}
.sticky-container .iphone.white {
background-color: var(--iphone-white-bg);
z-index: 20;
clip-path: inset(100% 0px 0px 0px);
}
.sticky-container .iphone.white h3 {
color: var(--iphone-white-text);
}
.sticky-container .iphone.white h3 span {
color: var(--iphone-white-text-highlight);
}
.sticky-container .iphone.red {
background-color: var(--iphone-red-bg);
z-index: 30;
clip-path: inset(100% 0px 0px 0px);
}
.sticky-container .iphone.red h3 {
color: var(--iphone-red-text);
}
.sticky-container .iphone.red h3 span {
color: var(--iphone-red-text-highlight);
}
.sticky-container.no-sticky {
position: relative;
overflow: visible;
}
.sticky-container.no-sticky .iphone {
position: relative;
}
.sticky-container.no-sticky .iphone.red {
padding-bottom: calc(var(--iphone-offscreen) * -1);
}
</style>
<script type="text/javascript">
window.addEventListener('scroll', (e) => {
let noStickyOffset = document.documentElement.clientHeight * 2
let scrolled = document.documentElement.scrollTop / noStickyOffset
let $white = document.querySelector('.white')
let $red = document.querySelector('.red')
$white.style.clipPath = `inset(${((0.5 - scrolled) / 0.5) * 100}% 0px 0px 0px)`
$red.style.clipPath = `inset(${((1 - scrolled) / 0.5) * 100}% 0px 0px 0px)`
if (scrolled >= 1) {
document.querySelector('.sticky-container').classList.add('no-sticky')
} else {
document.querySelector('.sticky-container').classList.remove('no-sticky')
}
})
</script>
</head>
<body>
<!--
https://www.apple.com/v/iphone-se/b/images/overview/finishes_black__b06syayq94wi_medium_2x.png
https://www.apple.com/v/iphone-se/b/images/overview/finishes_white__drv9fwq9vzwy_medium_2x.png
https://www.apple.com/v/iphone-se/b/images/overview/finishes_red__eqfv1ongy282_medium_2x.png
-->
<div class="sticky-container">
<div class="iphone black">
<h3>
Comes in Black.<br>
</h3>
<img src="https://www.apple.com/v/iphone-se/b/images/overview/finishes_black__b06syayq94wi_medium_2x.png">
</div>
<div class="iphone white">
<h3>
Comes in Black.<br>
<span>White</span>
</h3>
<img src="https://www.apple.com/v/iphone-se/b/images/overview/finishes_white__drv9fwq9vzwy_medium_2x.png">
</div>
<div class="iphone red">
<h3>
Comes in Black.<br>
White. <span>And Pow.</span>
</h3>
<img src="https://www.apple.com/v/iphone-se/b/images/overview/finishes_red__eqfv1ongy282_medium_2x.png">
</div>
</div>
</body>
</html>
iPhone SE切换颜色特效的更多相关文章
- 编写最简单的 iPhone 界面切换应用
编写最简单的 iPhone 界面切换应用 以下是在iOS中最简单的界面切换示例.使用了多个Controller,并演示Controller之间在切换界面时的代码处理. 实现的应用界面: 首先,创建 ...
- WPF如何实现类似iPhone界面切换的效果(转载)
WPF如何实现类似iPhone界面切换的效果 (version .1) 转自:http://blog.csdn.net/fallincloud/article/details/6968764 在论坛上 ...
- Android的Activity切换动画特效库SwitchLayout,视图切换动画库,媲美IOS
由于看了IOS上面很多开发者开发的APP的视图界面切换动画体验非常好,这些都是IOS自带的,但是Android的Activity等视图切换动画并没有提供原生的,所以特此写了一个可以媲美IOS视图切换动 ...
- easyui之自定义字体图标(鼠标覆盖时切换颜色)
项目要求是自定义字体图标,使用easyui框架结构,众所周知easyui强功能弱样式,字体图标其实就是一张图片.要达到切换图标颜色的效果,要么就是有两套图,使用js控制.但是我这个人比较懒,不喜欢做复 ...
- vue点击切换颜色限制个数(用了mui框架)
vue点击切换颜色 只能点击一个 <!doctype html> <head> <meta charset="UTF-8"> <title ...
- iphone 数字字段颜色兼容问题
在iphone手机中,有些字段的颜色会自动发生变化,在head中添加如下meta即可.<meta name = "format-detection" content=&quo ...
- dotnet OpenXML 转换 PathFillModeValues 为颜色特效
在 OpenXml 预设形状,有一些形状设置了 PathFillModeValues 枚举,此枚举提供了亮暗的蒙层特效.具体的特效是让形状选择一个画刷,在画刷上加上特效.如立体几何 Cube 形状,在 ...
- 2016苹果春季发布会 iPhone SE发布
配置如下 主屏尺寸:4英寸 主屏分辨率:1336x640像素 后置摄像头:1200万像素 前置摄像头:120万像素 电池容量:1624mAh 核心数:双核 操作系统:iOS 9 核心数:双核 CPU: ...
- Android实现Activity页面跳转切换动画特效
了解Android程序设计的人应该知道,在Android 2.0之后有了overridePendingTransition(),其中里面两个参数,一个是前一个activity的退出,另一个activi ...
随机推荐
- centos7修改服务器时区
查看时区设置 timedatectl 列出所有时区,通过键盘上下键进行浏览 timedatectl list-timezones 修改服务器时区为Africa/Lagos # 拉各斯的时区,UTC+1 ...
- MySQL高级语句(一)
一.MySQL高级进阶SQL 语句 1.SELECT 2.DISTINCT 3.WHERE 4.AND.OR 5.IN 6.BETWEEN 7.通配符.LIKE 8.ORDER BY 9.| | 连 ...
- 在vue-cli项目中定义全局 filter、method 方法
1.创建 filters.js(methods.js) 文件: 2.filters.js(methos.js) 中定义全局过滤方法: 1 export default { 2 /** 时间戳转换 */ ...
- 在 vue-cli 项目中 使用elementUI 的“自定义主题”功能
1.安装elementUI $ npm i element-ui -S 2.安装主题工具 npm i element-theme -g 3.安装chalk主题 npm 安装 npm i element ...
- 【OI】计算分子量 Molar mass UVa 1586 题解
题目:(由于UVa注册不了,还是用vjudge) https://vjudge.net/problem/UVA-1586 详细说明放在了注释里面.原创. 破题点在于对于一个元素的组合(元素+个数),只 ...
- 微信小程序自动化测试
使用官方工具 使用webview测试方法,当2019年被微信封禁 使用native定位
- centos实现免密登陆及远程操作
----------------------------**********------------------------------------------------- 免密码登陆 第一步: 执 ...
- MySQL数据库提权(一)
一.获取Mysql登录账号和密码 1.数据库提权需要知道数据库的账号密码.以及它的配置文件,一般配置文件都在网站的根目录下,这些配置文件命名有鲜明的特征,如:conn.config.data.sql. ...
- Redis高可用解决方案:哨兵(Sentinel)
哨兵是Redis的高可用解决方案:由多个哨兵组成的系统监视主从服务器,可以将下线的主服务器属下的某个从服 务器升级为新的主服务器,继续保障运行. 启动并初始化Sentinel redis-sentin ...
- 设置 SSH 命令行空闲保持会话
楔子 使用 Mac 或 Linux 原生的命令行 ssh user@ip 方式连接 Linux 闲时会自动断开终端卡死. 为解决这个问题,查了到篇博客翻译下关键步骤记录下来.解决方式可以分服务端设置和 ...