css小点心

多线程大师
• 阅读 1575

本文由作者邹欣华授权网易云社区发布。

有一个在邮件中用饼图直观地显示用户的各项消费比例的需求。邮箱中不能用js,纯css实现饼图,只能通过后端模版渲染数据,所以数据越少越简单越好。

想到css3的transform的rotate属性,rotate通过对指定的角度参数对元素指定一个角度的旋转。圆形的话用border-radius就可以实现,但是怎样通过旋转生成饼图。一个完整的圆不论怎样旋转都还只是一个圆,达不到要让每一个模块按比例显示出来的效果。但是可以用多个扇形组合成一个圆,然后通过旋转的角度差,显示各自的比例。旋转以后显示需要的部分,不需要的部分就要隐藏起来。又联想到了css2的clip属性。可以利用clip裁剪出想要的部分,rotate旋转出百分占比的区域,其余的部分通过透明遮罩隐藏起来,border-radius属性实现圆形效果。

第一步得到一个小扇形。

css小点心

裁剪圆的右边一半(clip:rect(0px,100px,200px,0px)),并且将右边半圆旋转20度(transform:rotate(20deg))。

第二步,接着生成多个扇形合成一个完整的圆。因为需求中不确定哪些内容需要展示,但是知道各自的数量以及总数,就可以计算出各自的占比,遮罩旋转的角度是前面所有扇形旋转角度的累加,扇形旋转的角度就是其百分比乘以360得出。

css小点心

这里需要提前在css中把所有可能出现的种类及对应的颜色定义好。clip属性只能在设置了”position:absolute”或者”position:fixed”属性起作用

透明遮罩的公共样式

.hold {

position:absolute;

width:200px;

height:200px;

clip:rect(0px,200px,200px,100px);

}

扇形区域的公共样式

.pie {

position:absolute;

width:200px;

height:200px;

clip:rect(0px,100px,200px,0px);

    border-radius:100px; 

}

第三步,将所有的扇形渲染完成就是一个完整的饼图了。因为数据是动态的所以需要特殊处理一下占比大于50%的情况。如果第一个扇形占比大于50%,需要旋转180度之后,再写一个同样颜色的扇形区域接着之前的旋转剩余的角度。旋转角度通过后端模版计算出来,所以通过style来定义。

css小点心

<div id="NVS" >

<div style="transform:rotate(180deg);"></div>

</div>

<div id="NVS" style="transform:rotate(180deg);">

<div style="transform:rotate(19.8deg);"></div>

</div>

还有一种特殊情况是扇形旋转的总角度和大于180,但是该扇形区域还有一部分未显示,需要将该部分旋转180减去前面部分的总和再写一个同样颜色的扇形区域接着之前的旋转该部分剩余的角度。

css小点心

<div id="NLB" >

<div style="transform:rotate(60deg);"></div>

</div>

<div id="CDN" style="transform:rotate(60deg);">

<div style="transform:rotate(120deg);"></div>

</div>

<div id="CDN" style="transform:rotate(180deg);">

<div style="transform:rotate(90deg);"></div>

</div>

最后的结果图。

css小点心

第一次接触到邮件中的需求,后来发现邮箱客户端css3的transform特性不支持,最后只能将饼图转换成图片放在页面中。并且考虑要outlook等邮箱客户端内核的不同,最好用table布局,并且图片要在页面中用img标签引入,譬如margin这样的属性会失效等。

   以上只是我的思路与做法,欢迎各路大神支招改进。
   附上各邮箱对css的支持情况:https://www.campaignmonitor.com/css/

免费领取验证码、内容安全、短信发送、直播点播体验包及云服务器等套餐

更多网易技术、产品、运营经验分享请访问网易云社区。

文章来源: 网易云社区

点赞
收藏
评论区
推荐文章
皕杰报表之UUID
​在我们用皕杰报表工具设计填报报表时,如何在新增行里自动增加id呢?能新增整数排序id吗?目前可以在新增行里自动增加id,但只能用uuid函数增加UUID编码,不能新增整数排序id。uuid函数说明:获取一个UUID,可以在填报表中用来创建数据ID语法:uuid()或uuid(sep)参数说明:sep布尔值,生成的uuid中是否包含分隔符'',缺省为
vue 简单实现 营销 转盘抽奖
1.0思路整理转盘抽奖很常见,之前也没写过,现在有空来写写,分析如下:1.1转盘旋转?可以用transform的rotate来解决1.2旋转动画?transition过渡来处理1.3停留目标位置及中奖提示?通过控制旋转角度控制停留位置,中奖提示,考虑添加回调1.1开始行
九路 九路
5年前
一篇文章带你了解CSS 渐变知识
CSS3渐变使您能够是你的背景颜色在两个或多个颜色之间平滑过渡。早些时候,你必须使用图像实现这些效果。然而,通过使用CSS3渐变可以减少下载时间和带宽的使用.此外,缩放的元素在缩放时看起来更好,因为渐变是由浏览器生成的。一、浏览器支持表中的数字指定完全支持该属性的第一个浏览器版本。(来源于百度)数字后面的w
徐小夕 徐小夕
5年前
如何使用css3实现一个类在线直播的队列动画
之前在群里有个朋友问了这样一个问题,就是如何在小程序中实现类似直播平台的用户上线时的队列动画?作为一名前端工程师,解决方案无非以下2种:1.使用javascript根据条件来控制元素的样式实现队列动画2.用纯css3配合数据驱动模型来实现.大家都知道在现代的Web开发中,我们能使用Css实现的效果尽量不要用Js,所以我们应该优先考虑用C
Python进阶者 Python进阶者
4年前
手把手教你使用CSS3为文本和元素实现添加阴影效果
使用CSS3,你可以为文本和元素添加阴影。一、浏览器支持表中的数字指定完全支持该属性的第一个浏览器版本。数字后面的webkit或者moz使用时需要指定前缀。|属性|Chrome|Firefox|Safari|Opera|IE|||||||||text
Wesley13 Wesley13
4年前
CSS3里的 转换与过渡动效
一、transform1.12D转换通过CSS3转换,能够对元素进行移动、缩放、转动、拉长或拉伸。1.旋转,deg表示角度。负的为逆时针转动,默认沿着中心点旋转。可以利用transformorigin设置旋转原点。transform:rotate(30deg);!(http
Stella981 Stella981
4年前
DataGear 制作支持表单交互操作和多图表联动的数据可视化看板
对于数据可视化,有时需要根据用户输入的查询条件展示限定范围的数据图表,DataGear(https://www.oschina.net/action/GoToLink?urlhttp%3A%2F%2Fwww.datagear.tech)的看板表单功能可以快速方便地实现此类需求。下面的看板示例,包含一个柱状图、一个饼图和一个地图,用户可以通过看板表单
Wesley13 Wesley13
4年前
Unity 围绕旋转角度限制(Transform.RotateAround)
    在Unity中可以利用Transform.RotateAround围绕指定物体进行旋转,但某些情况下可能需要对旋转角度进行控制。我是先计算出预设角度大小,然后判断是否小于或者超出旋转范围。如果小于则控制在最小范围内,如果大于则控制在最大范围内。相关代码如下://预设角度(当前角度加上将要增加/减少的角度
Wesley13 Wesley13
4年前
JS和CSS加载(渲染)机制不同
一、结论CSS可以在页面加载完成后随时渲染。举个例子:通过js给某个元素加一个id或者css,只要这个id或者css有对应的样式,此元素的样式就会自动生效。JS不可以在页面加载完成后生效。最明显的例子就是使用EasyUI的时候,iframe中哪些样式无效(EasyUi是依靠JS进行样式处理的,所以无法运行JS,那么样式也就无法设置。简单点说
Wesley13 Wesley13
4年前
Unity脚本
1,Transform旋转 transform.Rotate(X,Y,Z);//分别绕X,Y,Z轴旋转,可写为绕某个轴旋转,栗子transform.Rotate(0,90,0); transform.Rotate(Vector3.right\Time.deltaTime);//以欧拉角旋转,顺序是ZXY,right是向X轴
Stella981 Stella981
4年前
Android一个包含表格的图标库
之前有写过一个图表lib,但是开发的速度,大多很难跟上产品需求变化的脚步,所以修改了下原先的图表库,支持图表下面能整合table显示对应的类目,用曲线替换了折线,支持多曲线的显示,增加了显示的动画,,增加了一些可定制的属性,支持水平柱状图和叠加柱状图,以及多曲线图和饼状图的显示1.效果图!image(https://oscim