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

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

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

第一步得到一个小扇形。

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

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

这里需要提前在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来定义。

<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减去前面部分的总和再写一个同样颜色的扇形区域接着之前的旋转该部分剩余的角度。

<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>

最后的结果图。

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

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

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

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

相关文章:
【推荐】 Hadoop分布式集群的搭建
【推荐】 用双十一的故事串起碎片的网络协议(下)
【推荐】 HTTP/2部署使用

css小点心的更多相关文章

  1. ES6小点心第二弹——底部浮现弹窗

    小点心,顾名思义,开箱即食,拿来即用. 献上第二个小点心:SlidePopup. GitHub 在线演示 GitHub 上欢迎大家来找茬^_^ 前端朋友们,今天要介绍的这款小点心牛B了.相信是个前端都 ...

  2. css小技巧(1)

    1.-webkit-overflow-scrolling: touch; 解决ios滑动时无缓冲问题 2.::-webkit-scrollbar 设置ios滑动时是否显示滚动条 3.::selecti ...

  3. HTML+CSS小实战案例

    HTML+CSS小实战案例 登录界面的美化,综合最近所学进行练习 网页设计先布局,搭建好大框架,然后进行填充,完成页面布局 <html> <head> <meta htt ...

  4. CSS小tip整理

    CSS小tip整理 1.利用css在列表靠头和末尾添加箭头: /* 左箭头*/ ol a[rel="prev"]:before { content: "\00AB&quo ...

  5. css小细节罗列

    有空时候把一些常见可能不是每个人都知道的css小细节总结了下,共勉. 1.line-height 众多周知,line-height是行高的意思,我们时常会使用类似line-height:24px;这样 ...

  6. css小随笔(二)与通用样式

    51先在学校HTML5已经有半个多月了,然后这个星期做了一个京东的手机网站,接触到了通用样式,下面以京东的手机站为例 这两个就是京东手机站了的不同的两个板块,因为HTML5仅仅只是学完了基本标签跟cs ...

  7. ES6小点心之通用弹窗

    小点心,顾名思义,开箱即食,拿来即用. 前端业务逻辑主要分为[交互效果]和[数据展示]两方面.数据展示可使用 MVVM 框架来实现.前端的交互效果常用的也就那么几种,比如弹窗,楼层定位,倒计时,下拉刷 ...

  8. iconfont字体图标和各种CSS小图标

    前言:这是笔者学习之后自己的理解与整理.如果有错误或者疑问的地方,请大家指正,我会持续更新! iconfont字体图标 我们的需求中,很多时候会看到一些小的图形,或者叫图标,比如天猫网站中:     ...

  9. CSS 小技巧

    CSS 小技巧 一.边框内圆角 我们在设计例如按钮等控件的时候,会遇到这样的设计:只有内侧有圆角,而边框或者描边的四个角还是保持直角的形状,用以下代码可以轻松的实现. #wrapper { width ...

随机推荐

  1. 重哈希 · rehashing

    [抄题]: [思维问题]: [一句话思路]: [输入量]:空: 正常情况:特大:特小:程序里处理到的特殊情况:异常情况(不合法不合理的输入): [画图]: newindex = (hashTable[ ...

  2. nginx反向代理部署与演示(二)

    我们把LB01作为负载均衡器,WEB01和WEB02作为两台web服务器.   WEB01与WEB02虚拟主机配置如下:   我们修改nginx下的conf/nginx.conf文件,在http{}中 ...

  3. 02 请求库之 requests模块

    requests模块   一 介绍 #介绍:使用requests可以模拟浏览器的请求,比起之前用到的urllib,requests模块的api更加便捷(本质就是封装了urllib3) #注意:requ ...

  4. Mathtype使用技巧

    1. 打开/关闭MathType窗口 Alt+Ctrl+q:插入inline公式   Ctrl+S:更新公式到Word相应位置 Alt+F4:保存并关闭MathType窗口,返回Word. 2. 公式 ...

  5. 2015湖南湘潭 D 二分

    2015湖南湘潭第七届大学生程序设计比赛 D题 Fraction Accepted : 133   Submit : 892 Time Limit : 1000 MS   Memory Limit : ...

  6. Codeforces 612B. Wet Shark and Bishops 模拟

    B. Wet Shark and Bishops time limit per test: 2 seconds memory limit per test: 256 megabytes input: ...

  7. 使用phpExcel导出excel文件

    function export($log_list_export) { require "../include/phpexcel/PHPExcel.php"; require &q ...

  8. part1:1-embeded学习心态

    遇到问题,要冷静分析问题,采用排除法,个个排除查找问题之所在!切记!在没分析完自己问题之前,别把问题所在指向他人!

  9. mysql 导入导出摘要

    1.导入by数据文件. mysql>load data infile '文件路径' into table 表名 fields terminated by '字段分隔符' lines termin ...

  10. AJAX学习必备三本书

    <AJAX基础教程>AJAX必备图书之一.国内发行的第一本AJAX图书,也是目前最好的AJAX入门书,如果您是AJAX新手,此书是最好的入门图书.本书基本包括了实现Ajax需要了解的大部分 ...