小编给大家分享一下iphone刘海屏页面适配的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1. 下面是实现iphone
小编给大家分享一下iphone刘海屏页面适配的示例分析,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!
1. 下面是实现iphonex 刘海屏前端页面适配的一个插值算法小案例
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Title</title>
<style>
body, ul {
margin: 0;
}
ul {
padding-left: 10px;
}
li {
list-style: none;
}
.phone {
position: relative;
width: 600px;
height: 300px;
border: 10px solid #000;
border-radius: 30px;
margin: 100px auto 0;
}
.content, .content ul {
width: 100%;
height: 100%;
}
.content {
overflow-x: hidden;
overflow-y: scroll;
}
.camera {
position: absolute;
top: 60px;
left: 0;
width: 26px;
height: 180px;
background-color: black;
border-radius: 0 30px 30px 0;
}
li + li {
border-top: 1px solid #ccc;
}
li {
font-size: 16px;
padding: 5px;
}
*::-WEBkit-scrollbar {
padding-left: 100px;
}
</style>
</head>
<body>
<div class="phone">
<div class="content">
<ul>
<li>SweeTanGo</li>
<li>Pacific Rose</li>
<li>SnapDragon</li>
<li>Envy</li>
<li>Koru (PluMac)</li>
<li>Pink Lady (Cripps Pink)</li>
<li>HoneYcrisp</li>
<li>Hoyal Gala</li>
<li>Macoun</li>
<li>SweeTango</li>
<li>Pacific Rose</li>
<li>SnapDragon</li>
<li>Envy</li>
<li>Koru (Plumac)</li>
<li>Pink Lady (Cripps Pink)</li>
<li>HoneYcrisp</li>
<li>Hoyal Gala</li>
<li>Macoun</li>
<li>Macoun</li>
<li>SweeTango</li>
<li>Pacific Rose</li>
<li>SnapDragon</li>
<li>Envy</li>
<li>Koru (Plumac)</li>
<li>Pink Lady (Cripps Pink)</li>
<li>HoneYcrisp</li>
<li>Hoyal Gala</li>
<li>Macoun</li>
<div class="camera"></div>
</ul>
</div>
</div>
<script>
~~function () {
var thresh = 20;
var maxoffset = 50;
var aLi = document.querySelectorAll('li');
var oCamera = document.querySelector('.camera');
var oContent = document.querySelector('.content')
var camPs = oCamera.getBoundinGClientRect();
~~function () {
oContent.onscroll = arguments.callee;
for (var item of aLi) {
var itemRect = item.getBoundingClientRect();
var dtf = itemRect.bottom - camPs.top
var dtb = itemRect.bottom - camPs.bottom
if (Math.abs(dtf) < 20) {
item.style.transfORM = 'translateX(' + lerp(0, 30, cal(dtf, 20)) + "px)";
} else if (dtf > 20 && dtb < -20) {
item.style.transform = 'translateX(' + 30 + "px)";
} else if (Math.abs(dtb) <20) {
item.style.transform = 'translateX(' + lerp(30, 0, cal(dtb, 20)) + "px)";
} else {
//全部移除摄像头区域
item.style.transform = 'translateX(' + 0 + "px)";
}
}
}()
}()
function lerp(p1, p2, t) {
return (p2 - p1) * t + p1
}
function cal(dis, thr) {
return (dis + thr) / (thr * 2)
}
</script>
</body>
</html>
以上是“iphone刘海屏页面适配的示例分析”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注编程网node.js频道!
--结束END--
本文标题: iphone刘海屏页面适配的示例分析
本文链接: https://www.lsjlt.com/news/78885.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
2022-06-04
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0