大家好,欢迎来到IT知识分享网。
uCharts高性能跨平台图表库,支持H5图表、APP图表、小程序图表(微信小程序、支付宝小程序、百度小程序、头条小程序、小程序、360小程序),支持饼图、圆环图、线图、柱状图、区域图、雷达图、圆弧进度图、仪表盘、K线图、条状图、混合图、玫瑰图、漏斗图、词云图、地图。
一套代码编到7个平台
在uni-app里面会使用到统计图,和echarts类似,因为经常有用到uni-app开发一些app和小程序相关的项目,也经常用到图表相关的插件,推荐ucharts给大家,个人感觉还是不错的,种类多也比较完善,
支持图表类型
- 饼图 pie
- 圆环图 ring
- 线图 line(直线、曲线)
- 柱状图 column(分组、堆叠、温度计)
- 区域图 area(直线、曲线)
- 雷达图 radar
- 圆弧进度图 arcbar
- 仪表盘 gauge
- K线图 candle
- 混合图 mix(支持 Point、Line 直线曲线、Column、Area 直线曲线)
- 玫瑰图 rose(面积模式、半径模式)
- 词云图 word(横向、横纵混排)
- 漏斗图 funnel
- 地图 map
插件特点
- 改造后的插件可以跨端使用,支持 H5、小程序(微信/支付宝/百度/头条//360)、APP,调用简单方便、性能及体验极佳。
- 虽然没有 Echarts 及 F2 图表功能强大,但可以实现一套业务逻辑各端通用,并解决了支付宝小程序图表显示模糊等问题。
- 支持单页面多图表,demo 中单页 10 个图表,响应速度超快。
- 支持入场动画及 ToolTip 动画效果。
- 独特支持 横屏模式。
为何不用 Echarts?
- 相比 Echarts 及 F2 的复杂的设置,本插件几乎等于傻瓜式的配置。
- Echarts 在跨端使用更复杂,本插件只需要简单的两个 <canvas> 标签轻松区别搞定,代码整洁易维护。
- Echarts 在 iOS 端图表显示错位,只能引用网页解决。
- 本插件打包后的体积相比 Echarts 小很多很多,所以性能更好。
- 如果您是 uni-app 初学者,那么强烈建议您使用 uCharts,并且目前可以跨全端通用,减少工作量,增强一致性体验。
- 图表样式均可自定义,懂 JS 的都可以读懂插件源码,直接修改 u-charts.js 源码即可。
- 本插件经过大量测试,反复论证并加以改造而成,请各位放心使用。
快速上手
代码示例:
<template> <view class="qiun-columns"> <view class="qiun-bg-white qiun-title-bar qiun-common-mt" > <view class="qiun-title-dot-light">柱状图</view> </view> <view class="qiun-charts"> <!--#ifdef MP-ALIPAY --> <canvas canvas-id="canvasColumn" id="canvasColumn" class="charts" :style="{'width':cWidth*pixelRatio+'px','height':cHeight*pixelRatio+'px', 'transform': 'scale('+(1/pixelRatio)+')','margin-left':-cWidth*(pixelRatio-1)/2+'px','margin-top':-cHeight*(pixelRatio-1)/2+'px'}"></canvas> <!--#endif--> <!--#ifndef MP-ALIPAY --> <canvas canvas-id="canvasColumn" id="canvasColumn" class="charts"></canvas> <!--#endif--> </view> </view> </template> <script> import uCharts from '../../components/u-charts/u-charts.js'; var _self; var canvaColumn=null; export default { data() { return { cWidth:'', cHeight:'', pixelRatio:1, serverData:'' } }, onLoad() { _self = this; //#ifdef MP-ALIPAY uni.getSystemInfo({ success: function (res) { if(res.pixelRatio>1){ //正常这里给2就行,如果pixelRatio=3性能会降低一点 //_self.pixelRatio =res.pixelRatio; _self.pixelRatio =2; } } }); //#endif this.cWidth=uni.upx2px(750); this.cHeight=uni.upx2px(500); this.getServerData(); }, methods: { getServerData(){ uni.request({ url: 'https://www.easy-mock.com/mock/5cc586b64fc5576cba3d647b/uni-wx-charts/chartsdata2', data:{ }, success: function(res) { console.log(res.data.data) //下面这个根据需要保存后台数据,我是为了模拟更新柱状图,所以存下来了 _self.serverData=res.data.data; let Column={categories:[],series:[]}; //这里我后台返回的是数组,所以用等于,如果您后台返回的是单条数据,需要push进去 Column.categories=res.data.data.Column.categories; //这里的series数据是后台做好的,如果您的数据没有和前面我注释掉的格式一样,请自行拼接数据 Column.series=res.data.data.Column.series; _self.showColumn("canvasColumn",Column); }, fail: () => { console.log("网络错误,小程序端请检查合法域名"); }, }); }, showColumn(canvasId,chartData){ canvaColumn=new uCharts({ $this:_self, canvasId: canvasId, type: 'column', legend:true, fontSize:11, background:'#FFFFFF', pixelRatio:_self.pixelRatio, animation: true, categories: chartData.categories, series: chartData.series, xAxis: { disableGrid:true, }, yAxis: { }, dataLabel: true, width: _self.cWidth*_self.pixelRatio, height: _self.cHeight*_self.pixelRatio, extra: { column: { width: _self.cWidth*_self.pixelRatio*0.45/chartData.categories.length } } }); }, changeData(){ canvaColumn.updateData({ series: _self.serverData.ColumnB.series, categories: _self.serverData.ColumnB.categories }); } } } </script> <style> page{background:#F2F2F2;width: 750upx;overflow-x: hidden;} .qiun-padding{padding:2%; width:96%;} .qiun-wrap{display:flex; flex-wrap:wrap;} .qiun-rows{display:flex; flex-direction:row !important;} .qiun-columns{display:flex; flex-direction:column !important;} .qiun-common-mt{margin-top:10upx;} .qiun-bg-white{background:#FFFFFF;} .qiun-title-bar{width:96%; padding:10upx 2%; flex-wrap:nowrap;} .qiun-title-dot-light{border-left: 10upx solid #0ea391; padding-left: 10upx; font-size: 32upx;color: #000000} /* 通用样式 */ .qiun-charts{width: 750upx; height:500upx;background-color: #FFFFFF;} .charts{width: 750upx; height:500upx;background-color: #FFFFFF;} </style>
本人在uni-app小程序写的图表:
总结
uCharts在小程序端使用起来真的很方便的,几乎能满足我们所有的图表要求,确实比echarts好用的多,大家怎么看呢?
免责声明:本站所有文章内容,图片,视频等均是来源于用户投稿和互联网及文摘转载整编而成,不代表本站观点,不承担相关法律责任。其著作权各归其原作者或其出版社所有。如发现本站有涉嫌抄袭侵权/违法违规的内容,侵犯到您的权益,请在线联系站长,一经查实,本站将立刻删除。 本文来自网络,若有侵权,请联系删除,如若转载,请注明出处:https://yundeesoft.com/88460.html