Echarts的坑

Echarts总结

简介:js图标库,可以兼容在pc和移动端。Echarts底层使用canvas实现,支持多图表、组件的联动和混搭展现。

常用图表类型:折线图(区域图)、柱状图(条状图)、散点图(气泡图)、饼图(环形图)、雷达图(填充雷达图)等图表。

常用配置子组件:标题,详情气泡、图例、值域、数据区域、轴、工具箱等。

注: 本篇总结仅针对项目中使用的功能点整理总结,并不能涵盖Echart全部内容,更多需求请参考Echarts官方文档

1.tooltip(详情气泡)

配置实例:


tooltip: {

        trigger: 'axis',

        confine: true,

        backgroundColor: pointColor,

        textStyle: {

          color: '#fff',

        },

        formatter: function(params) {

// 区别定制每个tooltip浮动层中的文案

          return params[0].data.hasVal ? `${params[0].value} ${params[0].data.tipText}` : `${params[0].data.noValueText}`

        },

        axisPointer: {

          lineStyle: {

            color: 'rgba(139,185,255, 0.2)',

          },

        },

        // pos 鼠标当前位置, dom tooltip的dom对象, Echart容器当前尺寸

        position: function (pos, params, dom, rect, size) {

          let yPos = '0%' // 垂直方向固定在画布顶部

          let xPos = 0

          // 左侧的一部分数据

          if (pos[0] < size.viewSize[0] / 2) {

            xPos = pos[0] + 0  // 鼠标点位置,tootip在右

          } else { // 右侧的一部分数据

            xPos = pos[0] - dom.offsetWidth - 0 // 鼠标点位置减去tooltip的宽度,tooltip在左

          }

          return [xPos, yPos]

        },

      } 

各项说明如下:

-trigger: tooltip浮动层的触发方式, 'axis': 鼠标在整个画布上任意位置(整个坐标轴范围)均能触发,触发时会在鼠标最近图形上叠加显示轴线,主要在柱状图,折线图使用;'item':鼠标只能在数据项图形上面触发,例如折现图时,点击折点才能触发。注意: trigger的配置方式会影响其他tooltip配置项的配置。

-confine: 是否将 tooltip 框限制在图表的区域内。当图表外层的 dom 被设置为 'overflow: hidden',或者移动端窄屏,导致 tooltip 超出外界被截断时,此配置比较有用。

-backgroundColor/borderColor: tooltip浮层的背景颜色及边框颜色。注意: 此两种样式所有的tooltip均保持统一,不能根据数据进行对于某一个数据的tooltip特殊设置。

-textStyle: tooltip符层中字体的统一样式设置。

-axisPointer: 仅当tooltip的trigger配置为'axis'时有效

,设置叠加轴线的样式。

-formatter: formatter是tooltip中非常有用的一项配置。此项配置可以根据数据定制生成tooltip中的文本内容。如果没有改项配置,默认文本内容是横轴和纵轴的值。


  // formatter的配置

  // 1.字符串模版 

  // 模板变量有 {a}, {b},{c},{d},{e},分别表示系列名,数据名,数据值等。 详细内容请查询官网



  formatter: '{b0}: {c0}
{b1}: {c1}'



  // 2.回调函数

  // 回调函数参数 

  // (params: Object|Array, ticket: string, callback: (ticket: string, html: string)) => string

  // 在 trigger 为 'axis' 的时候,params 是多个系列的数据数组。每一项的格式如下

  {

    componentType: 'series', // 系列类型



    seriesType: string, // 系列在传入的 option.series 中的 index



    seriesIndex: number, // 系列名称



    seriesName: string, // 数据名,类目名

    name: string, // 数据在传入的 data 数组中的 index



    dataIndex: number, // 传入的原始数据项



    data: Object, // 传入的数据值



    value: number|Array, // 数据图形的颜色

    color: string,

}

  其中的data项可以用来区别每一项数据的文案,data的格式与series中的data项配置相关联,详细可见上例代码。

-position: tooltip的显示位置。指可以是数组,也可以是回调函数。


// 回调函数参数 (point, params, dom, rect, size),需要return出一个数组表示tooltip的位置。

point: 鼠标位置,如 [20, 40]。

params: 同 formatter 的参数相同。

dom: tooltip 的 dom 对象。

rect: 只有鼠标在图形上时有效,是一个用x, y, width, height四个属性表达的图形包围盒。

size: 包括 dom 的尺寸和 echarts 容器的当前尺寸

<font size=3 color=#D2691E>其中仅有point参数是与用户操作相关的位置变量,代表了用户触摸鼠标在画布上的位置。因此我们仅能跟据此项计算tooltip的位置,暂无方法知道距离鼠标点最近的数据点的位置,并让tooltip根据折点定位。</font>

tooltip未能实现的功能点:

tooltip根据距离鼠标点最近的数据点进行定位;轴线的高度与数据的高度一致,而不是纵向贯穿画布;折点覆盖轴线,层级在上

2. xAxis 及yAxis (横纵坐标轴)


  xAxis: {

      type: 'category',

      boundaryGap: false,

      data: xAxisData,

      axisLine: {

        show: false,

      },

      axisTick: {

        show: false,

      },

      axisLabel: {

        interval: 0,

        color: '#666',

      },

      formatter: function(params) {

return `${params}\\nn2017` // \\nn 换行符

      },

  },

  yAxis: {show: false},

-type: 'value',连续数据;'category',离散数据,最常用,必须通过data项来设置数据;'time',时间轴;'log': 对数轴

-boundaryGap: 坐标轴两边是否留白。

-data: 轴刻度点的数据。如果需要定制轴标签文字内容,需搭配使用formatter配置。

-axisLine:坐标轴线相关样式

-axisTick: 轴线上的刻度的相关样式。其中interval项控制刻度显示,有的时候需要间隔几个刻度显示一个,可以用此项来控制。或者手动将data中不显示的刻度值设置为空字符串。

-axisLabel: 轴标签的相关样式。

-formatter: 此项配置在官网xAxis配置文档中并不能查询到,但是可以使用。可以用来定制轴标签的显示内容,接收的params参数即为刻度点的data值。

<font size=3 color=#D2691E>注: 轴的formatter配置的换行效果与tooltip的formatter配置冲突,暂不明原因。</font>

3.grid(网格)

grid主要用来配置网格组件的显示及样式等

最常用的四个配置是<font size=3 color=#D2691E>left,top,right, bottom。这四项用来控制图形区域到画布边缘的留白。</font>取值可以是数字也可以是百分比。

4.series(图表类型及配置)

series是Echarts最必要也是最重要的配置。series是有单个图表配置对象组成的数组,当其length > 1时,表示了有多个分别设置的图表在画布上进行了叠加。由于图表类型过多,本篇仅选择折线图举例说明。


series: [{

          data: seriesData,

          // data: [820, 932, 901, 934, 1290, 1330, 1320],

          type: 'line',

          areaStyle: {color: areacolor},

          symbol: 'circle',

          symbolSize: 6,

          itemStyle: {

            normal: {

                color: pointColor,

                lineStyle: {

                    color: lineColor

                }

          }

        },

      }],

-data: 图表的数据。举例如下:


const datalist = [

{y: '1', color: 'red', tipText: '重度污染',hasVal: true},

{y: '1', color: 'blue', tipText: '空气良好',hasVal: true},

{y: '1', color: 'yellow', tipText: '中度污染',hasVal: true},

{y: '0', color: '', tipText: '',hasVal:false},

]

const seriesData = datalist.map((item,index) => {

    return {

        value: item.y, // Echart自带配置

        tipText: `${item.y} ${item.tipText}`, 

        hasVal: item.hasVal,

        noValueText: '空数据',

        emphasis: {

          itemStyle: {

              color:item. color

          }

        },

        themeColor,

        symbolSize: item.hasVal ? 8 : 0, // 有值的点展示,没有值的点不展示

      }

  })

其中,value, emphasis, symbolSize 是Echarts自带的配置,除此之外可任意添加配置项,注意不要与自带配置的key重读。

<font size=3 color=#D2691E>data中配置的每个字段都可以在tooltip中的formatter的通过其参数params[0].data来获取,可以用来帮助我们实现tooltip文案自定义。</font>具体请参阅上文tooltip中代码。

emphasis用来设置当某个折点被高亮时候的样式;symbolSize用来设置折点被高亮时候的大小。此两项是可以针对单个数据点进行设置的。

-type: 图表的类型。

-areaStyle: 图表的区域颜色,可以设置为渐变色。

-symbol: 折点的图形。ECharts 提供的标记类型包括 'circle', 'rect', 'roundRect', 'triangle', 'diamond', 'pin', 'arrow', 'none'。可以通过 'image://url' 设置为图片,其中 URL 为图片的链接,或者 dataURI。

-symbolSize: 折点没有高亮时大小,统一设置。

-itemStyle: 折线拐点的样式。

5.在React Native 项目中的使用

简单的图表,当要给Echart组件设置一个固定的宽高,组件会自动计算每个刻度的值,并在画布上画出。

而在RN项目中,当data的数据长度并不固定时,我们需要每个刻度的长度固定,则需要根据data的长度来计算Echart的长度值,对width属性进行设置。这样图表会更加美观,不会因为data数据变化时,刻度的长短变化出现跳动感。

也可以在Echart组件外面使用scrollView组件,以实现Echart的滚动。如下代码所示:


const {

  width: windowWidth,

  height: windowHeight,

} = Dimensions.get('window');

 // data是图表数据

  getChartWidth() {

    const {data} = this.props;

    return (windowWidth / 6) * data.length;

  } 



<ScrollView

    ref={(r) => { this.chartScroll = r; }}

    horizontal

    showsHorizontalScrollIndicator={false}

    onContentSizeChange={this.onContentSizeChange}

  >

    {

      seriesData.length > 0 ? 

      : null

    }





©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,125评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,293评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,054评论 0 351
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,077评论 1 291
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,096评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,062评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,988评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,817评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,266评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,486评论 2 331
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,646评论 1 347
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,375评论 5 342
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,974评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,621评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,796评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,642评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,538评论 2 352

推荐阅读更多精彩内容