千家信息网

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

发表于:2025-02-21 作者:千家信息网编辑
千家信息网最后更新 2025年02月21日,小编给大家分享一下怎么用纯CSS实现iPhone价格信息图,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!代码解读定义dom
千家信息网最后更新 2025年02月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安全错误 数据库的锁怎样保障安全 软件开发功能设置 java 服务器文件下载 软件开发技术教学大纲 基岩版服务器怎么装光影 指定代理服务器 authors 数据库 阿里巴巴数据库技术 网络没连接上苹果服务器 项目软件开发的经验和教训 象山ios软件开发管理 数据库配置为远程连接 pg查询数据库数据量大小 大数据软件开发技术是什么 什么是专用服务器结构 深圳在赫网络技术有限公司 淘宝卖服务器怎么分类 易语言写小程序服务器 发展信息网络技术 网络安全技术与实例 北京农行软件开发中心待遇 如何软件开发服务应用 网络安全 红黄牌制度 福州康为网络技术有限公司官网 服务器ip多少个算好的 oracal数据库安装及连接 杭州电商软件开发价钱 主机网络安全技术是 玩ufc说服务器超时是怎么回事 青岛软件开发云 ios软件开发账号 年费
0