当前位置: 首页 > news >正文

教育中介公司网站建设费用/网络营销的培训课程

教育中介公司网站建设费用,网络营销的培训课程,骏域网络科技有限公司,网站代运营 如何纳税本文由作者邹欣华授权网易云社区发布。 有一个在邮件中用饼图直观地显示用户的各项消费比例的需求。邮箱中不能用js,纯css实现饼图,只能通过后端模版渲染数据,所以数据越少越简单越好。 想到css3的transform的rotate属性,rotate通…

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

有一个在邮件中用饼图直观地显示用户的各项消费比例的需求。邮箱中不能用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/

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

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

文章来源: 网易云社区

http://www.lbrq.cn/news/1294327.html

相关文章:

  • 怎么让学生在网站上做问卷调查/百度收录入口在哪里
  • 高端网网站建设/网站推广营销运营方式
  • 求职网站开发多少钱/长春百度推广公司
  • 电商摄影/seo产品优化免费软件
  • crazyuncle WordPress/某网站seo诊断分析
  • html全部源码免费/北京seo优化诊断
  • 中山做网站优化/百度识图网页版 在线
  • 网站建设服务合同缴纳印花税吗/百度广告联盟怎么加入
  • php ajax网站开发/百度企业认证怎么认证
  • 医院建网站/百度收录api怎么提交
  • 中国建设银行江西分行网站首页/百度收录
  • 广州哪家做网站/长尾关键词挖掘工具
  • 做一家电商网站需要多少钱/企业网站模板 免费
  • 网站建设需求说明书/泉州搜索推广
  • 页面设计一般用什么软件/seo专业培训
  • 我司如何自己建设动态网站/关键词搜索引擎又称为
  • 信息课做网站的软件/seo咨询师
  • 做学校网站的目的是什么/恶意点击软件哪个好
  • 上海建筑工程股份有限公司/江西短视频seo搜索报价
  • 做的美食视频网站/百度推广可以自己开户吗
  • 澳门网站建设/免费学生网页制作成品代码
  • 酒店电子商务网站策划书/制作一个网站大概需要多少钱
  • 网站建设百度搜索到左边的图/网络营销管理
  • js网站建设/b站2020推广网站
  • 常德公司做网站/百度广告联盟平台的使用知识
  • 实验一html静态网站开发/百度上海总部
  • 直播视频网站如何做/营销管理制度范本
  • 如何建立免费网站的步骤/内江seo
  • 聊城哪里做优化网站/点击器
  • 网站 空间 备案/百度手机助手app官方下载
  • Linux学习之Linux系统权限
  • 【qml-3】qml与c++交互第二次尝试(类型方式)
  • 用户虚拟地址空间布局架构
  • 网鼎杯2020青龙组notes复现
  • 彩虹云商城全源码 - 全新客服系统上线
  • 7. 命令模式