删除图表上的网格线

时间:2012-12-22 11:13:36

标签: highcharts highstock

我有charts lib HighCharts,我想在图表上删除yAxis的网格线 我写gridLineWidth: 0 但网格线没有删除 所有代码:

<script type="text/javascript">
(function($){ // encapsulate jQuery

$(function() {
    Highcharts.setOptions({
        lang: {
            rangeSelectorZoom: 'Маcштаб',
            rangeSelectorFrom: 'От',
            rangeSelectorTo: 'До',
            thousandsSep: ' '
        },
        global: {
            useUTC: false
        }
    });

    $.getJSON('http://www.highcharts.com/samples/data/jsonp.php?filename=aapl-c.json&callback=?', function(data) {
        // Create the chart
        window.chart = new Highcharts.StockChart({
            chart : {
                borderColor: 'white',
                renderTo : <?php echo "cont".$i; ?>,
                backgroundColor: '#f9f9f9' // Сделаем слегка серый фон
            },

            rangeSelector: {
                buttons: [  
                { 
                    type: 'week', 
                    count: 1, 
                    text: 'Неделя',
                },  
                { 
                    type: 'month', 
                    count: 1, 
                    text: 'Месяц',
                },              
                { 
                    type: 'year', 
                    count: 1, 
                    text: 'Год'
                },
                {
                    type: 'all',
                    text: 'Всё'
                }],
                inputDateFormat: '%d.%m.%Y', // Меняем на привычный для нас формат даты в интервалах
                inputEditDateFormat: '%d.%m.%Y',
                buttonTheme: {
                    width: 43 // Увеличим ширину кнопки
                },
                selected: 1 // Какая кнопка выбрана по умолчанию
            },

            yAxis: [{
            gridLineWidth: 0,
            plotBands: [{ 
                 color: 'rgba(1, 143, 189, 1)',
                 from: -2,
                 to: 11
             },
             { 
                 color: 'rgba(157, 200, 5, 1)',
                 from: 11,
                 to: 21
             },
             { 
                 color: 'rgba(202, 1, 94, 1)',
                 from: 21,
                 to: 50
             }],


                title: {
                    text: 'Позиции'
                },
                startOnTick: false,
             //   min: 1,
                showFirstLabel: true,
                showLastLabel: true,
                reversed: true,
                tickPositioner: function(min, max) {
                    // specify an interval for ticks or use max and min to get the interval
                    var interval = Math.round((max-min)/5);
                    // push the min value at beginning of array
                    var dataMin=this.dataMin;
                    var dataMax=this.dataMax;          
                    var positions = [dataMin];
                    var defaultPositions = this.getLinearTickPositions(interval, dataMin, max);
                    //push all other values that fall between min and max
                    for (var i = 0; i < defaultPositions.length; i++) {
                        if (defaultPositions[i] > dataMin && defaultPositions[i] < dataMax) {
                            positions.push(defaultPositions[i]);
                        }
                    }
                    // push the max value at the end of the array
                    positions.push(dataMax);
                    return positions;
                },
                //changed min valuereversed: true
            }],
            navigator: {
                enabled: false,
                maskFill: 'rgba(255, 255, 255, 0.45)',
                //margin: 20,
                series: {
                    type: 'areaspline',
                    color: 'rgba(255, 255, 255, 0.00)',
                    fillOpacity: 0.4,
                    dataGrouping: {
                        smoothed: false
                    },
                    lineWidth: 2,
                    lineColor: '#e9cc00',
                    marker: {
                        enabled: false
                    },
                    shadow: true
                },
                yAxis: {
                    reversed: true
                }
            },
            xAxis : { 
                gridLineWidth: 0,
                type: 'datetime',
                title : {
                    text : ' '
                },
            },

            title : {
                //text : 'Позиции сайта'
            },
            legend: {
                enabled: true,
                align: 'center',
                itemWidth: 234, // указал ширину, чтобы выводились сайты в 4 колонки
                verticalAlign: 'top'
            },          
            series : [{
                lineColor: 'white',
                name : 'Позиция в яндексе',
                id : 'dataseries',
                data : <?php echo $d ?>,
                tooltip: {
                    backgroundColor: 'rgba(250, 250, 250, .85)', // Фон немного темнее
                    borderColor: 'rgba(100, 100, 100, .90)', // Цвет границы (по умолчанию меняется автоматом)
                    xDateFormat: '%d.%m.%Y %H:%M', // Наш формат даты
                    // Тут немного увеличиваем размер даты
                    headerFormat: '<span style="font-size: 12px">{point.key}</span><br/>',
                    // Формат надписей в подсказке, названия цветом графика, а значения жирным
                    pointFormat: '<span style="color:{series.color}">{series.name}</span>: <b>{point.y}</b><br/>',
                    //valueDecimals: 2
                }
            }]
        });
    });

});

})(jQuery);
</script>

5 个答案:

答案 0 :(得分:34)

问题不在于gridLineWidth。你已经正确设置了它。

此外,您需要将minorGridLineWidth设置为0

<强> Working demo

答案 1 :(得分:4)

如果您不想触摸配置对象,只需通过css隐藏网格:

.chart-container .highcharts-grid {
   display: none;
}

答案 2 :(得分:2)

以上提到的解决方案都不适合我,因此这一解决方案终于奏效(摘自Sparklines示例:https://www.highcharts.com/demo/sparkline):

yAxis: {
    startOnTick: false,
    endOnTick: false,
    tickPositions: [],
}

答案 3 :(得分:1)

对于所有其他行来说,这对我有用,在某些情况下使用行透明度,因为颜色是我能找到的唯一解决方案。

$(function() {                                                                                                                                               
  $('#container').highcharts({                                                                                                                               
    colors: ['#00f900', '#ffff3c', '#ff2600'],                                                                                                               
    credits: {                                                                                                                                               
      enabled: false                                                                                                                                         
    },                                                                                                                                                       
    exporting: {                                                                                                                                             
      enabled: false                                                                                                                                         
    },                                                                                                                                                       
    legend: {                                                                                                                                                
      itemDistance: 60                                                                                                                                       
    },                                                                                                                                                       
    lineColor: 'red',                                                                                                                                        
    chart: {                                                                                                                                                 
      type: 'column',                                                                                                                                        
      backgroundColor: 'transparent'                                                                                                                         
    },                                                                                                                                                       
    title: {                                                                                                                                                 
      text: ''                                                                                                                                               
    },                                                                                                                                                       
    legend: {                                                                                                                                                
      itemStyle: {                                                                                                                                           
        color: 'white',                                                                                                                                      
        fontWeight: 'normal',                                                                                                                                
        fontFamily: 'helvetica',                                                                                                                             
        fontSize: '12px'                                                                                                                                     
      }                                                                                                                                                      
    }
// ....rest in js fiddle

http://jsfiddle.net/fv50sLkj/23/

答案 4 :(得分:1)

you just need to gridLineWidth set to 0
yAxis: {
           min:0,
           categories: ["","Low","Medium","High"],
           tickWidth: 0,
           crosshair: false,
           lineWidth: 0,
           gridLineWidth:0,//Set this to zero
           title: '',
           labels: {
                       formatter: function () {
                           return this.value;labels
                           }            
                       },
                       showEmpty: false
}