echarts属性之gird

news/2024/10/30 9:26:43/

grid

直角坐标系内绘图网格,单个 grid 内最多可以放置上下两个 X 轴,左右两个 Y 轴。可以在网格上绘制折线图,柱状图,散点图(气泡图)。

在 ECharts 2.x 里单个 echarts 实例中最多只能存在一个 grid 组件,在 ECharts 3 中可以存在任意个 grid 组件。

例如下面这个 Anscombe Quartet 的示例:

所有属性

grid. id

string

组件 ID。默认不指定。指定则可用于在 option 或者 API 中引用组件。

grid. show 试一试

boolean

是否显示直角坐标系网格。

grid. zlevel

number

所有图形的 zlevel 值。

zlevel用于 Canvas 分层,不同zlevel值的图形会放置在不同的 Canvas 中,Canvas 分层是一种常见的优化手段。我们可以把一些图形变化频繁(例如有动画)的组件设置成一个单独的zlevel。需要注意的是过多的 Canvas 会引起内存开销的增大,在手机端上需要谨慎使用以防崩溃。

zlevel 大的 Canvas 会放在 zlevel 小的 Canvas 的上面。

grid. z = 2

number

组件的所有图形的z值。控制图形的前后顺序。z值小的图形会被z值大的图形覆盖。

z相比zlevel优先级更低,而且不会创建新的 Canvas。

grid. left = '10%' 试一试

stringnumber

grid 组件离容器左侧的距离。

left 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比,也可以是 'left''center''right'

如果 left 的值为 'left''center''right',组件会根据相应的位置自动对齐。

grid. top = 60 试一试

stringnumber

grid 组件离容器上侧的距离。

top 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比,也可以是 'top''middle''bottom'

如果 top 的值为 'top''middle''bottom',组件会根据相应的位置自动对齐。

grid. right = '10%' 试一试

stringnumber

grid 组件离容器右侧的距离。

right 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比。

grid. bottom = 60 试一试

stringnumber

grid 组件离容器下侧的距离。

bottom 的值可以是像 20 这样的具体像素值,可以是像 '20%' 这样相对于容器高宽的百分比。

grid. width = 'auto' 试一试

stringnumber

grid 组件的宽度。默认自适应。

grid. height = 'auto' 试一试

stringnumber

grid 组件的高度。默认自适应。

grid. containLabel 试一试

boolean

grid 区域是否包含坐标轴的刻度标签。

  • containLabel 为 false 的时候:
    • grid.left grid.right grid.top grid.bottom grid.width grid.height 决定的是由坐标轴形成的矩形的尺寸和位置。
    • 这比较适用于多个 grid 进行对齐的场景,因为往往多个 grid 对齐的时候,是依据坐标轴来对齐的。
  • containLabel 为 true 的时候:
    • grid.left grid.right grid.top grid.bottom grid.width grid.height 决定的是包括了坐标轴标签在内的所有内容所形成的矩形的位置。
    • 这常用于『防止标签溢出』的场景,标签溢出指的是,标签长度动态变化时,可能会溢出容器或者覆盖其他组件。
grid. backgroundColor = 'transparent' 试一试

Color

网格背景色,默认透明。

颜色可以使用 RGB 表示,比如 'rgb(128, 128, 128)' ,如果想要加上 alpha 通道,可以使用 RGBA,比如 'rgba(128, 128, 128, 0.5)',也可以使用十六进制格式,比如 '#ccc'

注意:此配置项生效的前提是,设置了 show: true

grid. borderColor = '#ccc' 试一试

Color

网格的边框颜色。支持的颜色格式同 backgroundColor。

注意:此配置项生效的前提是,设置了 show: true

grid. borderWidth = 1 试一试

number

网格的边框线宽。

注意:此配置项生效的前提是,设置了 show: true

grid. shadowBlur 试一试

number

图形阴影的模糊大小。该属性配合 shadowColor,shadowOffsetXshadowOffsetY 一起设置图形的阴影效果。

示例:

{shadowColor: 'rgba(0, 0, 0, 0.5)',shadowBlur: 10
}

注意:此配置项生效的前提是,设置了 show: true 以及值不为 transparent 的背景色 backgroundColor

grid. shadowColor 试一试

Color

阴影颜色。支持的格式同color

注意:此配置项生效的前提是,设置了 show: true

grid. shadowOffsetX 试一试

number

阴影水平方向上的偏移距离。

注意:此配置项生效的前提是,设置了 show: true

grid. shadowOffsetY 试一试

number

阴影垂直方向上的偏移距离。

注意:此配置项生效的前提是,设置了 show: true

 grid. tooltip

Object

本坐标系特定的 tooltip 设定。

提示框组件的通用介绍:

提示框组件可以设置在多种地方:

  • 可以设置在全局,即 tooltip

  • 可以设置在坐标系中,即 grid.tooltip、polar.tooltip、single.tooltip

  • 可以设置在系列中,即 series.tooltip

  • 可以设置在系列的每个数据项中,即 series.data.tooltip

 grid.tooltip. show = true 试一试

boolean

是否显示提示框组件。

包括提示框浮层和 axisPointer。

 grid.tooltip. trigger = 'item' 试一试

string

触发类型。

可选:

  • 'item'

    数据项图形触发,主要在散点图,饼图等无类目轴的图表中使用。

  • 'axis'

    坐标轴触发,主要在柱状图,折线图等会使用类目轴的图表中使用。

    在 ECharts 2.x 中只支持类目轴上使用 axis trigger,在 ECharts 3 中支持在直角坐标系和极坐标系上的所有类型的轴。并且可以通过 axisPointer.axis 指定坐标轴。

  • 'none'

    什么都不触发。

  grid.tooltip. axisPointer

Object

坐标轴指示器配置项。

tooltip.axisPointer 是配置坐标轴指示器的快捷方式。实际上坐标轴指示器的全部功能,都可以通过轴上的 axisPointer 配置项完成(例如 xAxis.axisPointer 或 angleAxis.axisPointer)。但是使用 tooltip.axisPointer 在简单场景下会更方便一些。

注意: tooltip.axisPointer 中诸配置项的优先级低于轴上的 axisPointer 的配置项。

坐标轴指示器是指示坐标轴当前刻度的工具。

如下例,鼠标悬浮到图上,可以出现标线和刻度文本。

上例中,使用了 axisPointer.link 来关联不同的坐标系中的 axisPointer。

坐标轴指示器也有适合触屏的交互方式,如下:

坐标轴指示器在多轴的场景能起到辅助作用:


注意: 一般来说,axisPointer 的具体配置项会配置在各个轴中(如 xAxis.axisPointer)或者 tooltip 中(如 tooltip.axisPointer)。

但是这几个选项只能配置在全局的 axisPointer 中:axisPointer.triggerOn、axisPointer.link。


如何显示 axisPointer:

直角坐标系 grid、极坐标系 polar、单轴坐标系 single 中的每个轴都自己的 axisPointer。

他们的 axisPointer 默认不显示。有两种方法可以让他们显示:

  • 设置轴上的 axisPointer.show(例如 xAxis.axisPointer.show)为 true,则显示此轴的 axisPointer。

  • 设置 tooltip.trigger 设置为 'axis' 或者 tooltip.axisPointer.type 设置为 'cross',则此时坐标系会自动选择显示哪个轴的 axisPointer,也可以使用 tooltip.axisPointer.axis 改变这种选择。注意,轴上如果设置了 axisPointer,会覆盖此设置。


如何显示 axisPointer 的 label:

axisPointer 的 label 默认不显示(也就是默认只显示指示线),除非:

  • 设置轴上的 axisPointer.label.show(例如 xAxis.axisPointer.label.show)为 true,则显示此轴的 axisPointer 的 label。

  • 设置 tooltip.axisPointer.type 为 'cross' 时会自动显示 axisPointer 的 label。


关于触屏的 axisPointer 的设置

设置轴上的 axisPointer.handle.show(例如 xAxis.axisPointer.handle.show 为 true 则会显示出此 axisPointer 的拖拽按钮。(polar 坐标系暂不支持此功能)。

注意: 如果发现此时 tooltip 效果不良好,可设置 tooltip.triggerOn 为 'none'(于是效果为:手指按住按钮则显示 tooltip,松开按钮则隐藏 tooltip),或者 tooltip.alwaysShowContent 为 true(效果为 tooltip 一直显示)。

参见例子。


自动吸附到数据(snap)

对于数值轴、时间轴,如果开启了 snap,则 axisPointer 会自动吸附到最近的点上。

所有属性

{ type , axis , snap , z , label , lineStyle , shadowStyle , crossStyle , animation , animationThreshold , animationDuration , animationEasing , animationDelay , animationDurationUpdate , animationEasingUpdate , animationDelayUpdate }

 grid.tooltip. position

stringArrayFunction

提示框浮层的位置,默认不设置时位置会跟随鼠标的位置。

可选:

  • Array

    通过数组表示提示框浮层的位置,支持数字设置绝对位置,百分比设置相对位置。

    示例:

      // 绝对位置,相对于容器左侧 10px, 上侧 10 pxposition: [10, 10]// 相对位置,放置在容器正中间position: ['50%', '50%']
    
  • Function

    回调函数,格式如下:

      (point: Array, params: Object|Array.<Object>, dom: HTMLDomElement, rect: Object, size: Object) => Array
    

    参数:
    point: 鼠标位置,如 [20, 40]。
    params: 同 formatter 的参数相同。
    dom: tooltip 的 dom 对象。
    rect: 只有鼠标在图形上时有效,是一个用xywidthheight四个属性表达的图形包围盒。
    size: 包括 dom 的尺寸和 echarts 容器的当前尺寸,例如:{contentSize: [width, height], viewSize: [width, height]}

    返回值:
    可以是一个表示 tooltip 位置的数组,数组值可以是绝对的像素值,也可以是相 百分比。
    也可以是一个对象,如:{left: 10, top: 30},或者 {right: '20%', bottom: 40}

    如下示例:

      position: function (point, params, dom, rect, size) {// 固定在顶部return [point[0], '10%'];}
    

    或者:

      position: function (pos, params, dom, rect, size) {// 鼠标在左侧时 tooltip 显示到右侧,鼠标在右侧时 tooltip 显示到左侧。var obj = {top: 60};obj[['left', 'right'][+(pos[0] < size.viewSize[0] / 2)]] = 5;return obj;}
    
  • 'inside'

    鼠标所在图形的内部中心位置,只在 trigger 为'item'的时候有效。

  • 'top'

    鼠标所在图形上侧,只在 trigger 为'item'的时候有效。

  • 'left'

    鼠标所在图形左侧,只在 trigger 为'item'的时候有效。

  • 'right'

    鼠标所在图形右侧,只在 trigger 为'item'的时候有效。

  • 'bottom'

    鼠标所在图形底侧,只在 trigger 为'item'的时候有效。

 grid.tooltip. formatter

stringFunction

提示框浮层内容格式器,支持字符串模板和回调函数两种形式。

1. 字符串模板

模板变量有 {a}{b}{c}{d}{e},分别表示系列名,数据名,数据值等。 在 trigger 为 'axis' 的时候,会有多个系列的数据,此时可以通过 {a0}{a1}{a2} 这种后面加索引的方式表示系列的索引。 不同图表类型下的 {a}{b}{c}{d} 含义不一样。 其中变量{a}{b}{c}{d}在不同图表类型下代表数据含义为:

  • 折线(区域)图、柱状(条形)图、K线图 : {a}(系列名称),{b}(类目值),{c}(数值), {d}(无)

  • 散点图(气泡)图 : {a}(系列名称),{b}(数据名称),{c}(数值数组), {d}(无)

  • 地图 : {a}(系列名称),{b}(区域名称),{c}(合并数值), {d}(无)

  • 饼图、仪表盘、漏斗图: {a}(系列名称),{b}(数据项名称),{c}(数值), {d}(百分比)

更多其它图表模板变量的含义可以见相应的图表的 label.formatter 配置项。

示例:

formatter: '{b0}: {c0}<br />{b1}: {c1}'

2. 回调函数

回调函数格式:

(params: Object|Array, ticket: string, callback: (ticket: string, html: string)) => string | HTMLElement | HTMLElement[]

支持返回 HTML 字符串或者创建的 DOM 实例。

第一个参数 params 是 formatter 需要的数据集。格式如下:

{componentType: 'series',// 系列类型seriesType: string,// 系列在传入的 option.series 中的 indexseriesIndex: number,// 系列名称seriesName: string,// 数据名,类目名name: string,// 数据在传入的 data 数组中的 indexdataIndex: number,// 传入的原始数据项data: Object,// 传入的数据值。在多数系列下它和 data 相同。在一些系列下是 data 中的分量(如 map、radar 中)value: number|Array|Object,// 坐标轴 encode 映射信息,// key 为坐标轴(如 'x' 'y' 'radius' 'angle' 等)// value 必然为数组,不会为 null/undefined,表示 dimension index 。// 其内容如:// {//     x: [2] // dimension index 为 2 的数据映射到 x 轴//     y: [0] // dimension index 为 0 的数据映射到 y 轴// }encode: Object,// 维度名列表dimensionNames: Array<String>,// 数据的维度 index,如 0 或 1 或 2 ...// 仅在雷达图中使用。dimensionIndex: number,// 数据图形的颜色color: string,// 饼图/漏斗图的百分比percent: number,// 旭日图中当前节点的祖先节点(包括自身)treePathInfo: Array,// 树图/矩形树图中当前节点的祖先节点(包括自身)treeAncestors: Array
}

注:encode 和 dimensionNames 的使用方式,例如:

如果数据为:

dataset: {source: [['Matcha Latte', 43.3, 85.8, 93.7],['Milk Tea', 83.1, 73.4, 55.1],['Cheese Cocoa', 86.4, 65.2, 82.5],['Walnut Brownie', 72.4, 53.9, 39.1]]
}

则可这样得到 y 轴对应的 value:

params.value[params.encode.y[0]]

如果数据为:

dataset: {dimensions: ['product', '2015', '2016', '2017'],source: [{product: 'Matcha Latte', '2015': 43.3, '2016': 85.8, '2017': 93.7},{product: 'Milk Tea', '2015': 83.1, '2016': 73.4, '2017': 55.1},{product: 'Cheese Cocoa', '2015': 86.4, '2016': 65.2, '2017': 82.5},{product: 'Walnut Brownie', '2015': 72.4, '2016': 53.9, '2017': 39.1}]
}

则可这样得到 y 轴对应的 value:

params.value[params.dimensionNames[params.encode.y[0]]]

在 trigger 为 'axis' 的时候,或者 tooltip 被 axisPointer 触发的时候,params 是多个系列的数据数组。其中每项内容格式同上,并且,

{componentType: 'series',// 系列类型seriesType: string,// 系列在传入的 option.series 中的 indexseriesIndex: number,// 系列名称seriesName: string,// 数据名,类目名name: string,// 数据在传入的 data 数组中的 indexdataIndex: number,// 传入的原始数据项data: Object,// 传入的数据值。在多数系列下它和 data 相同。在一些系列下是 data 中的分量(如 map、radar 中)value: number|Array|Object,// 坐标轴 encode 映射信息,// key 为坐标轴(如 'x' 'y' 'radius' 'angle' 等)// value 必然为数组,不会为 null/undefined,表示 dimension index 。// 其内容如:// {//     x: [2] // dimension index 为 2 的数据映射到 x 轴//     y: [0] // dimension index 为 0 的数据映射到 y 轴// }encode: Object,// 维度名列表dimensionNames: Array<String>,// 数据的维度 index,如 0 或 1 或 2 ...// 仅在雷达图中使用。dimensionIndex: number,// 数据图形的颜色color: string
}

注:encode 和 dimensionNames 的使用方式,例如:

如果数据为:

dataset: {source: [['Matcha Latte', 43.3, 85.8, 93.7],['Milk Tea', 83.1, 73.4, 55.1],['Cheese Cocoa', 86.4, 65.2, 82.5],['Walnut Brownie', 72.4, 53.9, 39.1]]
}

则可这样得到 y 轴对应的 value:

params.value[params.encode.y[0]]

如果数据为:

dataset: {dimensions: ['product', '2015', '2016', '2017'],source: [{product: 'Matcha Latte', '2015': 43.3, '2016': 85.8, '2017': 93.7},{product: 'Milk Tea', '2015': 83.1, '2016': 73.4, '2017': 55.1},{product: 'Cheese Cocoa', '2015': 86.4, '2016': 65.2, '2017': 82.5},{product: 'Walnut Brownie', '2015': 72.4, '2016': 53.9, '2017': 39.1}]
}

则可这样得到 y 轴对应的 value:

params.value[params.dimensionNames[params.encode.y[0]]]

第二个参数 ticket 是异步回调标识,配合第三个参数 callback 使用。 第三个参数 callback 是异步回调,在提示框浮层内容是异步获取的时候,可以通过 callback 传入上述的 ticket 和 html 更新提示框浮层内容。

示例:

formatter: function (params, ticket, callback) {$.get('detail?name=' + params.name, function (content) {callback(ticket, toHTML(content));});return 'Loading';
}
 grid.tooltip. valueFormatter

string

从 v5.3.0 开始支持

tooltip 中数值显示部分的格式化回调函数。

回调函数格式:

(value: number | string, dataIndex: number) => string

自 v5.5.0 版本起提供 dataIndex

示例:

// 添加 $ 前缀
valueFormatter: (value) => '$' + value.toFixed(2)
 grid.tooltip. backgroundColor = 'rgba(50,50,50,0.7)'

Color

提示框浮层的背景颜色。

 grid.tooltip. borderColor = '#333' 试一试

Color

提示框浮层的边框颜色。

 grid.tooltip. borderWidth 试一试

number

提示框浮层的边框宽。

 grid.tooltip. padding = 5 试一试

number

提示框浮层内边距,单位px,默认各方向内边距为5,接受数组分别设定上右下左边距。

使用示例:

// 设置内边距为 5
padding: 5
// 设置上下的内边距为 5,左右的内边距为 10
padding: [5, 10]
// 分别设置四个方向的内边距
padding: [5,  // 上10, // 右5,  // 下10, // 左
]
  grid.tooltip. textStyle

Object

提示框浮层的文本样式。

所有属性

{ color , fontStyle , fontWeight , fontFamily , fontSize , lineHeight , width , height , textBorderColor , textBorderWidth , textBorderType , textBorderDashOffset , textShadowColor , textShadowBlur , textShadowOffsetX , textShadowOffsetY , overflow , ellipsis }

 grid.tooltip. extraCssText  试一试

string

额外附加到浮层的 css 样式。如下为浮层添加阴影的示例:

extraCssText: 'box-shadow: 0 0 3px rgba(0, 0, 0, 0.3);'

http://www.ppmy.cn/news/1543062.html

相关文章

Mac开发环境配置- Shell/Homebrew/ruby

前言 从 macOS Catalina 开始&#xff0c;Mac 使用 zsh 作为默认登录 Shell 和交互式 Shell。当然你也可以修改默认Shell&#xff0c;但一般没这个必要。而实际开发中经常会遇到一些环境问题导致的报错&#xff0c;下面我们就讲一下一些常用库的环境配置以及原理。 一、Homeb…

【JavaEE初阶】网络原理—关于TCP协议值滑动窗口与流量控制,进来看看吧!!!

前言 &#x1f31f;&#x1f31f;本期讲解关于TCP协议的重要的机制“连接的建立和断开”~~~ &#x1f308;感兴趣的小伙伴看一看小编主页&#xff1a;GGBondlctrl-CSDN博客 &#x1f525; 你的点赞就是小编不断更新的最大动力 &#x1…

JavaEE-多线程初阶(1)

目录 1. 线程的概念 1.1 线程是是什么 1.2 为什么要有线程 1.3 线程和进程的区别 1.4 Java的线程和操作系统线程的关系 2. 第一个多线程程序 2.1 Hello Thread 2.2 使用jconsole观察线程 3. 创建线程 3.1 继承Thread类 3.2 实现Runnable接口 1. 线程的概念 1.1 线程…

深度生成模型 - 深度信念网络(DBN)篇

序言 深度信念网络&#xff08; Deep Belief Networks&#xff0c;DBN \text{Deep Belief Networks&#xff0c;DBN} Deep Belief Networks&#xff0c;DBN&#xff09;作为深度学习领域的一个重要里程碑&#xff0c;自 2006 2006 2006年由 Geoffrey Hinton \text{Geoffrey Hi…

Java 实现协同过滤算法推荐算法

1. 什么是协同过滤 协同过滤主要分为两种类型&#xff1a; 基于用户的协同过滤&#xff1a;根据用户之间的相似性推荐物品。例如&#xff0c;如果用户A和用户B的评分相似&#xff0c;那么用户A喜欢的物品也可能会被推荐给用户B。 基于物品的协同过滤&#xff1a;根据物品之间…

基于uniapp微信小程序的校园二手书交易系统

作者&#xff1a;计算机学姐 开发技术&#xff1a;SpringBoot、SSM、Vue、MySQL、JSP、ElementUI、Python、小程序等&#xff0c;“文末源码”。 专栏推荐&#xff1a;前后端分离项目源码、SpringBoot项目源码、Vue项目源码、SSM项目源码、微信小程序源码 精品专栏&#xff1a;…

Flume的安装配置

一、上传解压 tar -zxvf apache-flume-1.9.0-bin.tar.gz -C /usr/local/soft/#***在环境变量中增加如下命令&#xff0c;可以使用 soft 快速切换到 /usr/local/soft***alias softcd /usr/local/soft/ 二、配置环境变量 soft #重命名 mv apache-flume-1.9.0-bin/ flume-1.9.0…

用Python在Excel工作表中添加、修改及删除超链接

在创建Excel工作簿时&#xff0c;内部文档的互链、报告自动化生成或是创建外部资源快速访问路径是比较常见的需求。通过超链接&#xff0c;我们可以将工作表与外部资源、文件或网页无缝连接&#xff0c;提升数据的交互性和可读性。无论是为了快速导航、动态更新内容&#xff0c…