nvd3基於時間軸流程圖

doc
http://nvd3-community.github.io/nvd3/examples/documentation.html
https://github.com/mbostock/d3/wiki
http://pkuwwt.gitcafe.io/d3-tutorial-cn/about.htmljavascript

http://nvd3.org/livecode/index.html

unix timestamp不能格式化?

apparently, d3 uses 13 digits unix timestamp (including microseconds) and you have 10 digits unix timestamp. try doing this:css

.tickFormat(function(d) { return d3.time.format('%x')(new Date(d*1000)) });
```html

效果圖
java

{% extends "base.html" %}

{% block title %}graph{% endblock %}

{% block head %}
{{ super() }}
<link rel="stylesheet" href="{{ url_for('static', filename='css/nv.d3.css') }}">
<script src="{{ url_for('static', filename='js/d3.min.js') }}"></script>
<script src="{{ url_for('static', filename='js/nv.d3.min.js') }}"></script>
{% endblock %}

{% block body %}
<div class="uk-grid" style="margin:10px;">

{% for service in services %}
    <div class="uk-width-1-3">
    <strong>{{ service }}</strong>
    </div>

    <div class="uk-width-2-3">
        <ul class="uk-tab" data-uk-tab>
            <li class="uk-active" id="{{ service }}-hour"><a href="#">Hour</a></li>
            <li id="{{ service }}-day"><a href="#">Day</a></li>
            <li id="{{ service }}-week"><a href="#">Week</a></li>
            <li id="{{ service }}-month"><a href="#">Month</a></li>
            <li id="{{ service }}-year"><a href="#">Year</a></li>
        </ul>
        <svg id="{{ service }}" style='height:250px'/>
    </div>
{% endfor %}

</div>

<script type="text/javascript">
$(function() {
    $("svg").each(function(idx, data) {
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id');
        draw_graph(hostname, service, '-1h', '%H:%M');
    });

    $("li[id$=hour]").bind("click", function(){
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id').split('-')[0];
        draw_graph(hostname, service, '-1h', '%H:%M');
    });

    $("li[id$=day]").bind("click", function(){
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id').split('-')[0];
        draw_graph(hostname, service, '-1d', '%H:%M');
    });
    
    $("li[id$=week]").bind("click", function(){
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id').split('-')[0];
        draw_graph(hostname, service, '-1w', '%b %d');
    });

    $("li[id$=month]").bind("click", function(){
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id').split('-')[0];
        draw_graph(hostname, service, '-1m', '%b %d');
    });

    $("li[id$=year]").bind("click", function(){
        var hostname = "{{ hostname }}";
        var service = $(this).attr('id').split('-')[0];
        draw_graph(hostname, service, '-1y', '%b %d');
    });

    function draw_graph(hostname, service, period, xformat) {
        $.ajax({
            type: 'GET',
            url: "{{ url_for('api.rrd') }}",
            data: { 'hostname': hostname, 'service': service, 'period': period },
            dataType: 'json',
            success: function(data){
            nv.addGraph(function() {  
                var chart = nv.models.lineChart()
                    .useInteractiveGuideline(true)
                    //.showLegend(false)
                    //.color(d3.scale.category20c().range())
                ;
  

                /*chart.tooltip
                    .headerFormatter(function(d) { return d3.time.format('%x')(new Date(d)); })
                    .valueFormatter(function(d){ return d3.round(d, 3); })
                ;*/

                chart.xAxis
                    //.axisLabel('Date')
                    .ticks(8)
                    .tickFormat(function(d) { return d3.time.format(xformat)(new Date(d)); })
                    .showMaxMin(false)
                    .rotateLabels(-30)
                ;

                chart.yAxis
                    //.axisLabel('Traffic')
                    .tickFormat(d3.format('.4s'))
                    //.tickFormat(function(d) { return d3.round(d, 3); })
                    .showMaxMin(false)
                ;

                chart.xScale(d3.time.scale())
                ;

                chart.yScale(d3.scale.linear())
                ;
        
                d3.select('#'+service)
                    .datum(data)
                    .transition()
                    .duration(0)
                    .call(chart)
                ;
 
                nv.utils.windowResize(function() { d3.select('#chart svg').call(chart) })
                ;
 
                return chart;
            });
            },
        });
    };
})
</script>

{% endblock %}
相關文章
相關標籤/搜索