自定义d3月份或年份刻度格式

Mat*_*vis 12 d3.js

所以我在d3中创建了一个图表并使用了默认的x轴格式,

d3.axisBottom(x)
Run Code Online (Sandbox Code Playgroud)

输出如下图:

数月和数年

如何手动创建和自定义此格式?特别是,我想使用短月份名称,如"十月",以便"十月"不会掩盖下一年的标签.

Ger*_*ado 21

使用tickFormat在X轴格式化蜱.在您的情况下,.tickFormat(d3.timeFormat("%b"))将返回短月份名称(但它将使年份消失).

这是演示:

var svg = d3.select("body")
  .append("svg")
  .attr("width", 500)
  .attr("height", 100)   
            
var xScale = d3.scaleTime()
  .domain([new Date("2014-01-01"), new Date("2016-01-01")])
  .range([0, 450]);
        
var xAxis = d3.axisBottom(xScale)
  .tickFormat(d3.timeFormat("%b"));
  
svg.append("g")
  .call(xAxis);
Run Code Online (Sandbox Code Playgroud)
<script src="https://d3js.org/d3.v4.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

要保留月/年默认功能,您需要创建自己的自定义格式.

var xAxis = d3.axisBottom(xScale)
   .tickFormat(function(date){
       if (d3.timeYear(date) < date) {
         return d3.timeFormat('%b')(date);
       } else {
         return d3.timeFormat('%Y')(date);
       }
    });
Run Code Online (Sandbox Code Playgroud)

查看演示:

var svg = d3.select("body")
  .append("svg")
  .attr("width", 500)
  .attr("height", 100)   
            
var xScale = d3.scaleTime()
  .domain([new Date("2014-01-01"), new Date("2016-01-01")])
  .range([0, 500]);

var xAxis = d3.axisBottom(xScale)
  .tickFormat(function(date){
    if (d3.timeYear(date) < date) {
      return d3.timeFormat('%b')(date);
    } else {
      return d3.timeFormat('%Y')(date);
    }
  });
  
svg.append("g")
  .attr("class", "x axis")
  .call(xAxis);
	
d3.selectAll(".ticks");
Run Code Online (Sandbox Code Playgroud)
<script src="https://d3js.org/d3.v4.min.js"></script>
Run Code Online (Sandbox Code Playgroud)

  • 有没有办法保留显示年份的轴刻度的原始功能? (3认同)
  • 是的,我问的主要是因为有时我必须编写自定义函数以根据“ d”条件显示月份或年份,并且有时默认情况下它单独执行...有时它多次显示相同的刻度线...我觉得还是d3中我还不满意的部分之一。谢谢杰拉多,这些年来您已经帮助了我很多次 (2认同)
  • 对于还格式化周、天、小时的扩展版本,此示例可能会有所帮助:https://bl.ocks.org/wboykinm/34627426d84f3242e0e6ecb2339e9065 (2认同)