千家信息网

怎么用纯CSS实现iPhone价格信息图

发表于:2024-09-21 作者:千家信息网编辑
千家信息网最后更新 2024年09月21日,小编给大家分享一下怎么用纯CSS实现iPhone价格信息图,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!代码解读定义dom
千家信息网最后更新 2024年09月21日怎么用纯CSS实现iPhone价格信息图

小编给大家分享一下怎么用纯CSS实现iPhone价格信息图,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!

代码解读

定义dom,容器中包含3个元素,h2是图表标题,.back表示背景墙,.side表示侧边墙,.back和.side中都包含一个无序列表,背景墙展示价格,侧边墙展示名称:

iPhonePriceComparison

    $1099~$1449

    $999~$1349

    $749~$899

    $999~$1149

    iPhoneXSMax

    iPhoneXS

    iPhoneXR

    iPhoneX

居中显示:

body{

margin:0;

height:100vh;

display:flex;

align-items:center;

justify-content:center;

background:linear-gradient(lightblue,skyblue);

}

定义容器尺寸:

.wall{

width:60em;

height:40em;

border:1emsolidrgba(255,255,255,0.5);

border-radius:2em;

font-size:10px;

}

用grid布局,把容器分成2部分,左侧80%为背景墙,右侧20%为侧边墙:

.wall{

display:grid;

grid-template-columns:04fr1fr;

}

分别设置背景墙和侧边墙的背景色:

.back{

background:linear-gradient(

toright,

#555,

#ddd

);

}

.side{

background:

radial-gradient(

at0%50%,

/*tomato25%,

yellow90%*/

rgba(0,0,0,0.2)25%,

rgba(0,0,0,0)90%

),

linear-gradient(

toright,

#ddd,

#ccc

)

}

用flex布局设置对齐方式,列表垂直居中:

.back,

.side{

display:flex;

align-items:center;

}

.back{

justify-content:flex-end;

}

ul{

list-style-type:none;

padding:0;

}

设置标题样式:

h2{

position:relative;

width:20em;

margin:1em;

color:white;

font-family:sans-serif;

}

设置列表项的高度和颜色:

.backul{

width:75%;

}

.sideul{

width:100%;

}

ulli{

height:5em;

background-color:var(--c);

}

ulli:nth-child(1){

--c:tomato;

}

ulli:nth-child(2){

--c:coral;

}

ulli:nth-child(3){

--c:lightsalmon;

}

ulli:nth-child(4){

--c:deepskyblue;

}

至此,整体布局完成。接下来设置左侧背景墙的横条样式。

横条的宽度根据与商品的上限售价--high-price成正比,以最贵的售价--max-price作为全长,其他横条的宽度为上限售价与最高售价的百分比:

ul{

display:flex;

flex-direction:column;

}

.backul{

align-items:flex-end;

}

ul{

--max-price:1449;

}

ulli.xs-max{

--high-price:1449;

}

ulli.xs{

--high-price:1349;

}

ulli.xr{

--high-price:899;

}

ulli.x{

--high-price:1149;

}

.backulli{

width:calc(var(--high-price)/var(--max-price)*100%);

}

在横条中区分起售价--low-price的位置,比起售价高的区域填充更深的颜色:

ulli.xs-max{

--low-price:1099;

--c2:orangered;

}

ulli.xs{

--low-price:999;

--c2:tomato;

}

ulli.xr{

--low-price:749;

--c2:coral;

}

ulli.x{

--low-price:999;

--c2:dodgerblue;

}

.backulli{

--percent:calc(var(--low-price)/var(--high-price)*100%);

background:linear-gradient(

toleft,

var(--c)var(--percent),

var(--c2)var(--percent)

);

}

在横线的顶端画出一个向左的三角形:

.backulli{

position:relative;

}

.backulli::before{

content:'';

position:absolute;

width:0;

height:0;

transform:translateX(-3em);

border-right:3emsolidvar(--c2);

border-top:2.5emsolidtransparent;

border-bottom:2.5emsolidtransparent;

}

设置价格文字样式:

.backullispan{

position:absolute;

width:95%;

text-align:right;

color:white;

font-size:1.25em;

line-height:4em;

font-family:sans-serif;

}

为各横条增加阴影,增强立体感:

ulli.xs-max{

z-index:5;

}

ulli.xs{

z-index:4;

}

ulli.xr{

z-index:3;

}

ulli.x{

z-index:2;

}

.backulli{

filter:drop-shadow(01em1emrgba(0,0,0,0.3));

}

至此,背景墙的横条完成。接下来设置侧边墙的样式。

为了制造立体效果,需要设置侧边墙的景深,并使列表倾斜:

.side{

perspective:1000px;

}

.sideul{

transform-origin:left;

transform:rotateY(-75deg)scaleX(4);

}

设置侧边墙的文字样式:

.wall{

overflow:hidden;

}

.sideulli{

padding-right:30%;

text-align:right;

color:white;

font-family:sans-serif;

line-height:5em;

}

至此,静态视觉效果完成。最后增加入场动画效果:

ulli{

animation:show1slinearforwards;

transform-origin:right;

transform:scaleX(0);

}

@keyframesshow{

to{

transform:scaleX(1);

}

}

.backulli{

animation-delay:1s;

}

以上是"怎么用纯CSS实现iPhone价格信息图"这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注行业资讯频道!

很赞哦!
背景 边墙 售价 样式 价格 容器 布局 效果 篇文章 至此 信息 接下来 上限 内容 宽度 文字 标题 立体 颜色 更深 数据库的安全要保护哪些东西 数据库安全各自的含义是什么 生产安全数据库录入 数据库的安全性及管理 数据库安全策略包含哪些 海淀数据库安全审计系统 建立农村房屋安全信息数据库 易用的数据库客户端支持安全管理 连接数据库失败ssl安全错误 数据库的锁怎样保障安全 贵州学习软件开发服务商 sql2008数据库分享 淘宝网络技术问题 共同维护网络安全艺术字 新一代软件开发设施应用 服务器是做什么用的具体有什么 英魂之刃怎么选服务器 服务器开机卡在选择管理员界面 星星网络安全评估的方法 芜湖手机软件开发公司如何选择 加马互联网科技工作 浅谈计算机网络安全管理 常见的数据库检索算法 济宁管理软件开发哪家靠谱 通讯软件开发平均价格 达梦数据库结束上市辅导 暗黑三国服数据库 我的世界宝可梦服务器热门 安徽网络安全与信息化委员会 软件开发职业现状和发展趋势 关于网络安全法的学习体会 数据库中主键和唯一索引的区别有 软件开发哪些岗位 w型服务器 全境封锁2怎么换地区服务器 济南晨平网络技术有限公司级别 深圳手机软件开发常见问题 金山网络安全基础服务器 网络时代什么网络技术最挣钱 网络安全知识小报怎么画
0