企业🤖AI智能体构建引擎,智能编排和调试,一键部署,支持私有化部署方案 广告
# 坐标轴(Axis) 所有的图表除了饼图都有X轴和Y轴,默认情况下,x轴显示在图表的底部,y轴显示在左侧(多个y轴时可以是显示在左右两侧),通过设置[`chart.inverted = true`](http://www.highcharts.me/demo/index.php?p=13 "点击查看演示") 可以让x,y轴显示位置对调。下图为图表中坐标轴组成部分 ![](https://box.kancloud.cn/2016-05-04_572991784755f.jpg)图表坐标轴组成部分 ### 一、坐标轴组成部分 #### 1、Axis Title 坐标轴标题。默认情况下,x轴为`null`(也就是没有title),y轴为`'Value'`,设置坐标轴标题的代码如下: ``` xAxis:{ title:{ text:'x轴标题' } } yAxis:{ title:{ text:'y轴标题' } } ``` 更多关于Axis Title属性请查看API文档相关内容 [xAxis.title](http://www.highcharts.me/api/index.php#xAxis.title)、[yAxis.title](http://www.highcharts.me/api/index.php#yAxis.title)。 #### 2、Axis Labels 坐标轴标签(分类)。Labels常用属性有`enabled`、`formatter`、`setp`、`staggerLines` ##### 1)enabled 是否启用Labels。x,y轴默认值都是`true`,如果想禁用(或不显示)Labels,设置该属性为`false`即可。 ##### 2)Formatter 标签格式化函数。默认实现是: ``` formatter:function(){ return this.value; } ``` `this.value`代码坐标轴上当前点的值(也就是x轴当前点的x值,y轴上当前点的y值),除了`value`变量外,还有`axis`、`chart`、`isFirst`、`isLast`可用。例如调用this.isFirst的结果如下图所示 ![](https://box.kancloud.cn/2016-05-04_5729917868a46.jpg)Custom Labels formatter 1 另外一个例子,实现更高级的自定义格式化函数,截图如下: ![](https://box.kancloud.cn/2016-05-04_572991788596f.jpg)Custom Labels formatter 2 实现代码如下: ``` yAxis: { labels: { formatter:function(){ if(this.value <=100) { return "第一等级("+this.value+")"; }else if(this.value >100 && this.value <=200) { return "第二等级("+this.value+")"; }else { return "第三等级("+this.value+")"; } } } }, ``` ##### 3)Step Labels显示间隔,数据类型为number(或int)。下图说明了step的用法和作用 ![](https://box.kancloud.cn/2016-05-04_572991789d463.jpg)Y Lables width step ##### 4)staggerLines 水平轴Lables显示行数。(该属性只对水平轴有效)当Lables内容过多时,可以通过该属性控制显示的行数。和该属性相关的还有[maxStaggerLines](http://www.highcharts.me/api/index.php#yAxis.labels.maxStaggerLines)属性。 更多关于Lables的属性请查看API文档 [xAxis.labels](http://www.highcharts.me/api/index.php#xAxis.labels)、[yAxis.labels](http://www.highcharts.me/api/index.php#yAxis.labels) #### 3、Axis Tick Tick为坐标轴刻度。默认情况下x轴刻度高(`tickLength`属性)为5px,宽为1px;y轴宽为0px(也就是不显示刻度)。Tick相关的属性主要有`tickLength`、`tickWidth`、`tickColor`、`tickInterval`、`tickmarkPlacement`。 ##### 1)tickLength、tickWidth、tickColor 分别代表刻度线的长度、宽度、颜色。 ##### 2)tickInterval 刻度间隔。其作用和`Lables.step`类似,就是不显示过多的x轴标签内容,不同的是,`tickInterval`是真正意义上的调整刻度,而`Lables.step`只是调整Labels显示间隔。所以在实际应用中,`tickInterval`用的多。 针对不同数据类型的坐标轴有不同的默认值。对于线性数据和`Datetime`类型数据,其默认值是[tickPixelInterval](http://www.highcharts.me/api/index.php#xAxis.tickPixelInterval)值,对于`Categorty`表示间隔一个category。 关于`tickInterval`的作用,请访问博客中相关内容 《[如何处理Highcharts X轴数据过多时显示问题](http://www.52wulian.org/highcharts-tickinterval/)》。 ##### 3)tickmarkPlacement 刻度线对齐方式,有`between`和`on`可选,默认是`between`。设置为`on`后的变化如下图: ![](https://box.kancloud.cn/2016-05-04_57299178c25e0.jpg)xAxis tickmarkPlacement on 更多关于Tick的属性请查看API文档。 #### 4、Axis gridLines 坐标轴网格线。默认情况下,x轴网格线宽度为0,y轴网格线宽度为1px。网格线共有三个属性可设置,分别是: `gridLineWidth`、`gridLineColor`、`gridLineDashStyle` ##### 1)gridLineWidth 网格线宽度。x轴默认为0,y轴默认为1px。 ##### 2)gridLineColor 网格线颜色。默认为:`#C0C0C0`。 ##### 3)gridLineDashStyle 网格线线条样式。和Css border-style类似,常用的有:`Solid`、`Dot`、`Dash`。 下图为自定义x和y轴的gridLines效果图 ![](https://box.kancloud.cn/2016-05-04_57299178e2292.jpg)Custom gridLines #### 4、multiple Axis 多个轴。在Highcharts中, 坐标可以是多个,最常见的是多个y轴。多轴存在时,Axis是一个数组,而在赋值时,通过Axis数组的下标与数据关联。如下图所示: ![](https://box.kancloud.cn/2016-05-04_572991790bc25.jpg)About multiple Axis 总结如下: * `Series`中设置每个轴值时,用轴数组下标关联。 * 设置`opposite: true`表示该轴位置反转,即为y轴时显示在右侧,为x轴时显示在顶部(和正常情况下x轴在下,y轴左构成反转)。 * 在`Series`中可以设置该轴的类型,多个轴不同的类型(例如:type:'spline'),就构成了多种图表并存的混合图。 更多关于多轴、混合图请查看在线演示平台的 [两个(Y)轴的混合图](http://www.highcharts.me/demo/index.php?p=52)、[多个(Y)轴的混合图](http://www.highcharts.me/demo/index.php?p=53)。 ### 二、坐标轴类型 坐标轴中,可以通过`Type`指定坐标轴类型,有`linear`、`logarithmic`、`datetime`、`category`可选,默认是:`linear`。指定类型的实例代码如下: ``` // The types are 'linear', 'logarithmic' and 'datetime' yAxis: { type: 'linear', } // Categories are set by using an array xAxis: { categories: ['Apples', 'Bananas', 'Oranges'] } ``` #### 1、linear 线性轴。默认类型,x轴按照`Axis.tickInterval`值增长,y轴默认是自适应。 #### 2、logarithmic 对数轴。按照数学中的对数增长,例如1,2,4,8... 用的不多,主要用于对数图表,实例请查看在线演示平台的 [对数直线图](http://www.highcharts.me/demo/index.php?p=17)。 #### 3、datetime 时间轴。时间使用和Javascript 日期对象一样,即用一个距1970年1月1日0时0分0秒的毫秒数表示时间,也就是时间戳。更多Javascript 日期对象请阅读 [W3C school](http://www.w3school.com.cn/js/js_obj_date.asp) 相关内容。 Highcharts有很多时间格式化函数,列举如下: ##### 1)Date.getTime() 获取当前时间戳。实例用法如下: ``` time = Date.getTime(); //time = 1384442746960 (ms) 当前时间为 2013-11-14 23:25:46 ``` ##### 2)Date.UTC(year,month,day,hours,minutes,seconds,millisec) 通过UTC方式获取指定时间的毫秒数,例如获取 2013-11-14 00:00:00的毫秒数代码如下: ``` time = Date.UTC(2013,11,14,0,0,0,0); // time = 1386979200000 (ms); ``` ##### 3)Highcharts.dateFormat(String format) Highcharts时间格式化函数,同 [PHP格式化函数](http://php.net/manual/en/function.strftime.php)。具体用法参考API文档 [Highcharts.dateFormat()](http://www.highcharts.me/api/index.php#Highcharts.dateFormat()) ,当然,在本教程的《函数使用》章节中具体讲解。 #### 4、category 数组轴。用的最多也最简单,这里就不多说,更多请查看[在线演示平台](http://www.highcharts.me/demo/index.php)例子。 ### 三、动态更新及其他相关属性 #### 1、动态更新 坐标轴可以通过函数实现动态更新,在图表绘制完毕后,你可以任意的对你更改而不需要重绘。所有相关函数都在 [Axis](http://www.highcharts.me/api/index.php#Axis) 中,本教程将在《函数使用》章节具体讲解。 #### 2、其他相关属性 出了Axis中的属性可以对坐标轴有影响外,还有其他属性也可以对其起作用。列举如下: ##### 1)reversed 图表反转,即 `Chart.reversed`,当其值设置为`true`时,x轴和y轴显示的位置对调。详情请查看在线演示平台 [轴反转的曲线图](http://www.highcharts.me/demo/index.php?p=13)。 ##### **2)****allowDecimals** 控制数轴是否显示小数。 ##### **3)****min、max** 控制数轴的最小值和最大值。 注意:控制allowDecimals、min、max 属性你可以轻松控制数轴的显示范围等(这也是很常见的问题) ##### **4)opposite** 轴倒置。和reversed不同的是,倒置是将轴倒置而不是x、y对调。例如y轴倒置的结果是y轴是从最大的值开始的,最小值反而在最下方。 ##### **5)plotLines** 标示线,详见:[http://www.hcharts.cn/docs/index.php?doc=basic-plotLines](http://www.hcharts.cn/docs/index.php?doc=basic-plotLines) ##### **6)plotBands** 标示区域,详见:[http://www.hcharts.cn/docs/index.php?doc=basic-plotBands](http://www.hcharts.cn/docs/index.php?doc=basic-plotBands) * * * (正文完,最后更新时间:2014-06-24 19:18:07)