最后更新于:2022-04-01 11:11:27

> [Wiki](Home) ▸ [[API--中文手册]] ▸ [[SVG函数]] ▸ **SVG 轴** * 本文档是D3官方文档中文翻译,并保持与[最新版](https://github.com/mbostock/d3/wiki/API-Reference)同步。 * 如发现翻译不当或有其他问题可以通过以下方式联系译者: * 邮箱:zhang_tianxu@sina.com * QQ群:[D3数据可视化](http://jq.qq.com/?_wv=1027&k=ZGcqYF)205076374,[大数据可视化](http://jq.qq.com/?_wv=1027&k=S8wGMe)436442115 D3的轴组件自动展示比例尺参照的线。这使得你可以专注于展示数据,而轴组件需要关心绘制坐标轴和刻度标记的繁琐任务。 Axis 轴组件设计来和D3的定量,时间和序数比例尺一起使用。 # d3.svg.axis() 创建一个默认的轴。 # axis(selection) 将轴应用到选择和过渡上。选择必须包含svg或者g元素。例如: d3.select("body").append("svg") .attr("class", "axis") .attr("width", 1440) .attr("height", 30) .append("g") .attr("transform", "translate(0,30)") .call(axis); # axis.scale([scale]) 如果指定了scale 参数则设置刻度尺,并返回轴。如果未指定scale参数,将返回当前的刻度尺,默认为线性刻度。 # axis.orient([orientation]) 如果指定了方向orientation 参数则设置orientation ,并返回轴。如果未指定orientation参数,将返回当前的刻度尺,默认为“bottom”。支持下面几种方向: • top -刻度位于横轴域路径上面 • bottom -刻度位于横轴域路径下面 • left -刻度位于纵轴域路径左边 • right -刻度位于纵轴域路径右边 如果指定的方向是不支持的值之一,该轴将恢复为默认的方向。改变方向将影响刻度和它们的标签相对于轴路径的的位置,但不改变该轴本身的位置; 为了改变轴相对于基址图的位置,可以指定g元素上的transform 变换属性。 # axis.ticks([arguments…]) 如果指定了arguments 参数,存储指定的参数为之后来用生成刻度并返回轴。参数之后会传递给scale.ticks生成刻度值(除非刻度值通过明确地指定axis.tickValues)。参数将传递给比例尺的tickFormat方法用来生成默认的刻度格式。如果没有指定参数,返回当前的刻度参数,默认是[10]。 合适的参数取决于关联的比例尺:对于线性比例尺,你可以指定刻度数为axis.ticks(20);对于对数比例尺你可以指定数量和刻度格式;对于时间比例尺,时间间隔例如axis.ticks(d3.time.minutes, 15)可能更合适。 # axis.tickValues([values]) 如果指定了values 数组,指定的values 将用于刻度,而不是使用使用比例尺的自动刻度生成器。如果values 是null,清空任何预先设定的明确的刻度值,回到原来比例尺的生成器。如果没有指定values ,返回当前设定的刻度值,默认是null。例如,为了生成刻度为指定的values : var xAxis = d3.svg.axis() .scale(x) .tickValues([1, 2, 3, 5, 8, 13, 21]); 明确地刻度值优先于通过使用axis.ticks设置刻度参数。但是,任何的参数都仍然传递给比例尺的tickFormat 函数,如果一个刻度格式也没设置;这样,设置axis.ticks和axis.tickValues它可能有效。 # axis.tickSize([inner, outer]) 如果指定了inner和outer,设置内部和外部刻度尺寸为指定的值并返回轴。如果inner和outer没有指定,返回当前的内部刻度尺寸,默认是6。 # axis.innerTickSize([size]) 如果指定了size ,设置内部刻度尺寸为指定的值并返回轴。如果没有指定size ,返回当前的内部刻度尺寸,默认是6。内部刻度尺寸控制刻度线的长度,从轴的原生位置偏移。 # axis.outerTickSize([size]) 如果指定了size ,设置外部刻度尺寸为指定的值,并返回轴。如果没有指定size ,返回当前的外部刻度尺寸,默认是6。外部刻度尺寸控制域路径末尾的平方长度,从轴的原生位置偏移。这样,因此,“外刻度”实际上不是刻度但是域路径的一部分,并且它们的位置由相关的比例尺的域范围来确定。这样,外刻度可能与第一个或最后内部刻度重叠。外刻度尺寸0的禁止域路径的平方端,而不是产生一条直线。 # axis.tickPadding([padding]) 如果指定填充边距,设置填充边距的指定值并返回对应的axis。如果没有指定填充边距,返回当前默认填充边距(默认为3像素)。 # axis.tickFormat([format]) 如果指定格式,格式设置为指定的函数并返回axis。如果没有指定格式,返回当前格式函数,默认为空。空格式表示应该使用比例尺的默认格式器,此格式通过调用scale.tickFormat产生。在这种情况下,指定的参数同样传递给scale.tickFormat方法。 查看d3.format创建格式的帮助。例如,axis.tickFormat(d3.format(.0f“))将通过逗号分组千位显示一个整数。首先定义格式器:var commasFormatter = d3.format(”,.0f”) 可以让你把它作为你的数据的函数,例如,在comma-grouped整数前添加“$”符号:.tickFormat(function(d) { return "$" + commasFormatter(d); })。 注意:对于对数比例尺,刻度的数值不能自定义;然而,刻度的数值标签可以通过ticks自定义。同样,对数比例尺刻度的格式器通常是通过ticks而不是tickFormat指定,以保持默认label-hiding行为。 * axis.scale axis.orient小屁孩翻译,咕噜校正20140425 21:40:39 * axis.tickPadding axis.tickFormat魏飞20140427译 咕噜校对 2014-11-29 17:03:41 * 其余 咕噜译 2014-11-29 16:56:20
';