Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/403.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181

Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/83.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript Highcharts设置从上午12点开始到晚上11点结束的xAxis值_Javascript_Jquery_Highcharts - Fatal编程技术网

Javascript Highcharts设置从上午12点开始到晚上11点结束的xAxis值

Javascript Highcharts设置从上午12点开始到晚上11点结束的xAxis值,javascript,jquery,highcharts,Javascript,Jquery,Highcharts,我正在使用highcharts插件,我的目标是按小时绘制全天的图表 如何将xAxis设置为使用12小时格式(w/AM&PM),开始=>一天结束。或者选择间隔3小时 例如,我为今天和昨天 我的数据,如下所示(时间戳和值): 以下是我的完整脚本: $(function(){ var moneySign = "$"; Highcharts.setOptions({ lang: { thousandsSep: ',' } });

我正在使用highcharts插件,我的目标是按小时绘制全天的图表

如何将xAxis设置为使用12小时格式(w/AM&PM),开始=>一天结束。或者选择间隔3小时

例如,我为
今天
昨天

我的数据,如下所示(时间戳和值):

以下是我的完整脚本:

  $(function(){
    var moneySign = "$";

    Highcharts.setOptions({
      lang: {
        thousandsSep: ','
      }
    });        

    // Sales Chart
    var SalesChart = Highcharts.chart('ba-chart-sales', {
      title: { text: '' },
      exporting: { enabled: false },
      subtitle: { text: '' },
      yAxis: {
        title: { text: '' },            
        useHTML: true,
        labels: {
          formatter: function() {
            return moneySign + this.axis.defaultLabelFormatter.call({
              axis: this.axis,
              value: this.value
            });
          }
        }
      },
      xAxis: {
        // Default for 7days & 30days (will change for today||yesterday)
        type: 'datetime',
        dateTimeLabelFormats: { day: '%b %e' },
        tickInterval: 24 * 3600 * 1000 // interval of 1 day      
      },
      legend: {
        layout: 'vertical',
        align: 'right',
        verticalAlign: 'middle',
        enabled:false
      },
      tooltip: {
        dateTimeLabelFormats: { day: '%B %e, %Y' },
        shared: true,
        useHTML: true,
        headerFormat: '{point.key}<div>',
        pointFormat: '<div style="background-color: #0549d1; height: 10px; width: 10px; border-radius: 50%; display: inline-block;"></div>' +
                     '<div style="margin-left: 5px; margin-top: 8px; width:30px; display: inline-block;"><b> ' + moneySign + '{point.y}</b></div>',
        footerFormat: '</div>',
        crosshairs: {
          color: '#ccc',
          className: 'chart-crosshair',
          dashStyle: 'solid',
          width: 1
        }
      },
      plotOptions: {
        series: {
          label: {
            connectorAllowed: false
          },
          marker: {
            enabled: false,
            symbol: 'circle'
          }
        }
      },
      series: [{
        tooltip: { xDateFormat: '%B %e, %Y' },
        showInLegend: false,
        name: '',
        data: []
      }],
      responsive: rules: [{
        condition: {
          maxWidth: 600
        },
        chartOptions: {
          legend: {
            layout: 'horizontal',
            align: 'center',
            verticalAlign: 'bottom'
          }
        }
      }],
      credits: { enabled: false }
    });


    // Initial
    var SalesChartExtremes = SalesChart.yAxis[0].getExtremes();

    // Change Cart Type `line` || `column`
    function reDrawChart(filter, chart) {
      var series  = SalesChart.series[0];
      var newType = ['today', 'yesterday'].includes(filter) ? 'column' : 'line';      
      series.chart.addSeries({
        type: newType,
        name: series.name,
        color: series.color,
        data: series.options.data,
      }, false);
      series.remove();
    }

    // Get Offer Analytics Data
    function getAnalytics(filter=''){
      $.ajax({
        type: "GET",
        url: "<%= analytics_url %>",
        data: {chart_filter: filter},
        dataType: "JSON",
        success: function(data){
          var todayLocalDate = "<%= @local_time.strftime("%Y-%m-%d") %>".split('-').map(Number);
          var yesterdayLocalDate = "<%= @local_time.yesterday.strftime("%Y-%m-%d") %>".split('-').map(Number);

          if( ['30', '7', ''].includes(filter) ){
            var toolTipProp = { xDateFormat: '%B %e, %Y' };
            var pointIntervalProp = 24 * 3600 * 1000; // one day
            var pointStartProp = '';
            var chartType = 'line';
          }else{
            if (filter == 'today'){
              var pointStartProp = Date.UTC(todayLocalDate[0], todayLocalDate[1], todayLocalDate[2]);
            }else if (filter == 'yesterday'){
              var pointStartProp = Date.UTC(yesterdayLocalDate[0], yesterdayLocalDate[1], yesterdayLocalDate[2]);
            }
            var toolTipProp = { xDateFormat: '%B %e, %Y %I:%M%p' };
            var pointIntervalProp = 3600000 * 3; // 3 hours
            var chartType = 'column';
          }

          var markerEnabled = data.sales.length == 1
          var salesOpts = {
            tooltip: toolTipProp,
            data: data.sales,
            animation: { duration: 1000 },
            pointInterval: pointIntervalProp,
            pointStart: pointStartProp,
            crosshair: true,
            marker: {
              enabled: markerEnabled
            }
          }

          // Sets yAxis min & max values for empty result
          if(data.sales.length == 0){
            SalesChart.yAxis[0].setExtremes(0,100);
            SalesChart.yAxis[0].update({tickInterval: 20});
          }else{
            // return to previous categories based on data
            SalesChart.yAxis[0].setExtremes(SalesChartExtremes.min, SalesChartExtremes.max);
            SalesChart.yAxis[0].update({tickInterval: 500});
          }        

          if(filter == 'today' || filter == 'yesterday'){
            var defaultTimeOpt = {
              tickInterval: 1,
              type: 'datetime',
              dateTimeLabelFormats: {
                millisecond: '%l:%M:%S.%L %P',
                second: '%l:%M:%S %P',
                minute: '%l:%M %P',
                hour: '%l:%M %P',
                day: '(%e. %b) %l:%M %P'
              }
            }
            SalesChart.xAxis[0].update(defaultTimeOpt, true);

          }else{
            // return to day options
            var defaultDayOpt = {
              type: 'datetime',
              dateTimeLabelFormats: { day: '%b %e' },
              tickInterval: 24 * 3600 * 1000 // interval of 1 day
            }

            SalesChart.xAxis[0].update(defaultDayOpt, false);            
          }


          SalesChart.series[0].update(salesOpts, true);          
          reDrawChart(filter, 'sales');

        },
        error: function(data) {
          flashError("Error getting analytics");          
        }
      });
      return false;
    }

  });

// Call getAnalytics when select dropdown filter change (e.g. today, yesterday, lastweek ...)
getAnalytics();
$(函数(){
var moneySign=“$”;
Highcharts.setOptions({
朗:{
千塞普:','
}
});        
//销售图表
var SalesChart=Highcharts.chart('ba-chart-sales'{
标题:{文本:'},
正在导出:{enabled:false},
副标题:{文本:'},
亚克斯:{
标题:{文本:'},
是的,
标签:{
格式化程序:函数(){
return moneySign+this.axis.defaultLabelFormatter.call({
轴:这个轴,
值:这个值
});
}
}
},
xAxis:{
//默认为7天和30天(将更改为今天| |昨天)
键入:“日期时间”,
dateTimeLabelFormats:{day:'%b%e'},
间隔时间:24*3600*1000//间隔1天
},
图例:{
布局:“垂直”,
对齐:“右”,
垂直排列:'中间',
已启用:false
},
工具提示:{
dateTimeLabelFormats:{day:'%B%e,%Y'},
分享:是的,
是的,
headerFormat:“{point.key}”,
点格式:“”+
''+moneySign+'{point.y}',
页脚格式:“”,
十字准星:{
颜色:“#ccc”,
类名:“图表十字线”,
dashStyle:'实心',
宽度:1
}
},
打印选项:{
系列:{
标签:{
允许的连接器:false
},
标记:{
启用:false,
符号:“圆圈”
}
}
},
系列:[{
工具提示:{xDateFormat:'%B%e,%Y'},
showInLegend:false,
名称:“”,
数据:[]
}],
响应:规则:[{
条件:{
最大宽度:600
},
图表选项:{
图例:{
布局:“水平”,
对齐:'居中',
垂直排列:“底部”
}
}
}],
信用证:{已启用:错误}
});
//首字母
var SalesChartExtremes=SalesChart.yAxis[0].getExtremes();
//更改购物车类型'line`| ``列`
函数重绘图表(过滤器、图表){
var series=SalesChart.series[0];
var newType=['today','Dayed'].包括(筛选器)-'column':'line';
series.chart.addSeries({
类型:newType,
名称:series.name,
颜色:series.color,
数据:series.options.data,
},假);
系列。删除();
}
//获取报价分析数据
函数getAnalytics(过滤器=“”){
$.ajax({
键入:“获取”,
url:“”,
数据:{chart_filter:filter},
数据类型:“JSON”,
成功:功能(数据){
var todayLocalDate=“.split('-').map(编号);
var yesterdayLocalDate=”“.split('-').map(编号);
如果(['30','7','')。包括(筛选器)){
var toolTipProp={xDateFormat:“%B%e,%Y'};
var pointIntervalProp=24*3600*1000;//一天
var pointStartProp='';
var chartType='行';
}否则{
如果(过滤器==“今天”){
var pointStartProp=Date.UTC(todayLocalDate[0],todayLocalDate[1],todayLocalDate[2]);
}else if(过滤器==“昨天”){
var pointStartProp=Date.UTC(yesterdayLocalDate[0],yesterdayLocalDate[1],yesterdayLocalDate[2]);
}
var-toolTipProp={xDateFormat:“%B%e,%Y%I:%M%p'};
var pointIntervalProp=3600000*3;//3小时
var chartType='列';
}
var markerEnabled=data.sales.length==1
var salesOpts={
工具提示:工具提示,
数据:data.sales,
动画:{持续时间:1000},
pointInterval:pointIntervalProp,
pointStart:pointStartProp,
十字准星:没错,
标记:{
已启用:标记已启用
}
}
//为空结果设置yAxis最小值和最大值
if(data.sales.length==0){
SalesChart.yAxis[0].setextrems(0100);
SalesChart.yAxis[0]。更新({tickInterval:20});
}否则{
//根据数据返回到以前的类别
SalesChart.yAxis[0].setextrems(saleschartextrems.min,saleschartextrems.max);
SalesChart.yAxis[0]。更新({tickInterval:500});
}        
if(filter==“今天”| filter==“昨天”){
var defaultTimeOpt={
时间间隔:1,
键入:“日期时间”,
日期时间标签格式:{
毫秒:“%l:%M:%S.%l%P”,
第二个:“%l:%M:%S%P”,
分钟:“%l:%M%P”,
小时数:“%l:%M%P”,
日期:“(%e.%b)%l:%M%P”
}
}
SalesChart.xAxis[0]。更新(defaultTimeOpt,true);
}否则{
//返回日选项
var defaultDayOpt={
键入:“日期时间”,
dateTimeLabelFormats:{day:'%b%e'},
间隔时间:24*3600*1000//间隔1天
}
SalesChart.xAxis[0]。更新(defaultDayOpt,false);
}
SalesChart.series[0]。更新(salesOpts,true);
重画图表(过滤“销售”);
},
错误:函数(数据){
闪光器(“获取分析的错误”);
}
});
返回false;
}
});
  $(function(){
    var moneySign = "$";

    Highcharts.setOptions({
      lang: {
        thousandsSep: ','
      }
    });        

    // Sales Chart
    var SalesChart = Highcharts.chart('ba-chart-sales', {
      title: { text: '' },
      exporting: { enabled: false },
      subtitle: { text: '' },
      yAxis: {
        title: { text: '' },            
        useHTML: true,
        labels: {
          formatter: function() {
            return moneySign + this.axis.defaultLabelFormatter.call({
              axis: this.axis,
              value: this.value
            });
          }
        }
      },
      xAxis: {
        // Default for 7days & 30days (will change for today||yesterday)
        type: 'datetime',
        dateTimeLabelFormats: { day: '%b %e' },
        tickInterval: 24 * 3600 * 1000 // interval of 1 day      
      },
      legend: {
        layout: 'vertical',
        align: 'right',
        verticalAlign: 'middle',
        enabled:false
      },
      tooltip: {
        dateTimeLabelFormats: { day: '%B %e, %Y' },
        shared: true,
        useHTML: true,
        headerFormat: '{point.key}<div>',
        pointFormat: '<div style="background-color: #0549d1; height: 10px; width: 10px; border-radius: 50%; display: inline-block;"></div>' +
                     '<div style="margin-left: 5px; margin-top: 8px; width:30px; display: inline-block;"><b> ' + moneySign + '{point.y}</b></div>',
        footerFormat: '</div>',
        crosshairs: {
          color: '#ccc',
          className: 'chart-crosshair',
          dashStyle: 'solid',
          width: 1
        }
      },
      plotOptions: {
        series: {
          label: {
            connectorAllowed: false
          },
          marker: {
            enabled: false,
            symbol: 'circle'
          }
        }
      },
      series: [{
        tooltip: { xDateFormat: '%B %e, %Y' },
        showInLegend: false,
        name: '',
        data: []
      }],
      responsive: rules: [{
        condition: {
          maxWidth: 600
        },
        chartOptions: {
          legend: {
            layout: 'horizontal',
            align: 'center',
            verticalAlign: 'bottom'
          }
        }
      }],
      credits: { enabled: false }
    });


    // Initial
    var SalesChartExtremes = SalesChart.yAxis[0].getExtremes();

    // Change Cart Type `line` || `column`
    function reDrawChart(filter, chart) {
      var series  = SalesChart.series[0];
      var newType = ['today', 'yesterday'].includes(filter) ? 'column' : 'line';      
      series.chart.addSeries({
        type: newType,
        name: series.name,
        color: series.color,
        data: series.options.data,
      }, false);
      series.remove();
    }

    // Get Offer Analytics Data
    function getAnalytics(filter=''){
      $.ajax({
        type: "GET",
        url: "<%= analytics_url %>",
        data: {chart_filter: filter},
        dataType: "JSON",
        success: function(data){
          var todayLocalDate = "<%= @local_time.strftime("%Y-%m-%d") %>".split('-').map(Number);
          var yesterdayLocalDate = "<%= @local_time.yesterday.strftime("%Y-%m-%d") %>".split('-').map(Number);

          if( ['30', '7', ''].includes(filter) ){
            var toolTipProp = { xDateFormat: '%B %e, %Y' };
            var pointIntervalProp = 24 * 3600 * 1000; // one day
            var pointStartProp = '';
            var chartType = 'line';
          }else{
            if (filter == 'today'){
              var pointStartProp = Date.UTC(todayLocalDate[0], todayLocalDate[1], todayLocalDate[2]);
            }else if (filter == 'yesterday'){
              var pointStartProp = Date.UTC(yesterdayLocalDate[0], yesterdayLocalDate[1], yesterdayLocalDate[2]);
            }
            var toolTipProp = { xDateFormat: '%B %e, %Y %I:%M%p' };
            var pointIntervalProp = 3600000 * 3; // 3 hours
            var chartType = 'column';
          }

          var markerEnabled = data.sales.length == 1
          var salesOpts = {
            tooltip: toolTipProp,
            data: data.sales,
            animation: { duration: 1000 },
            pointInterval: pointIntervalProp,
            pointStart: pointStartProp,
            crosshair: true,
            marker: {
              enabled: markerEnabled
            }
          }

          // Sets yAxis min & max values for empty result
          if(data.sales.length == 0){
            SalesChart.yAxis[0].setExtremes(0,100);
            SalesChart.yAxis[0].update({tickInterval: 20});
          }else{
            // return to previous categories based on data
            SalesChart.yAxis[0].setExtremes(SalesChartExtremes.min, SalesChartExtremes.max);
            SalesChart.yAxis[0].update({tickInterval: 500});
          }        

          if(filter == 'today' || filter == 'yesterday'){
            var defaultTimeOpt = {
              tickInterval: 1,
              type: 'datetime',
              dateTimeLabelFormats: {
                millisecond: '%l:%M:%S.%L %P',
                second: '%l:%M:%S %P',
                minute: '%l:%M %P',
                hour: '%l:%M %P',
                day: '(%e. %b) %l:%M %P'
              }
            }
            SalesChart.xAxis[0].update(defaultTimeOpt, true);

          }else{
            // return to day options
            var defaultDayOpt = {
              type: 'datetime',
              dateTimeLabelFormats: { day: '%b %e' },
              tickInterval: 24 * 3600 * 1000 // interval of 1 day
            }

            SalesChart.xAxis[0].update(defaultDayOpt, false);            
          }


          SalesChart.series[0].update(salesOpts, true);          
          reDrawChart(filter, 'sales');

        },
        error: function(data) {
          flashError("Error getting analytics");          
        }
      });
      return false;
    }

  });

// Call getAnalytics when select dropdown filter change (e.g. today, yesterday, lastweek ...)
getAnalytics();
xAxis: {
    labels: {
        //isPm() is a function that checks for am and pm of your timestamp
        format: '{value} ' + (isPm() ? "pm":"am")
    }
}
xAxis: {
    type: 'datetime',
    dateTimeLabelFormats: {
      millisecond: '%l:%M:%S.%L %P',
      second: '%l:%M:%S %P',
      minute: '%l:%M %P',
      hour: '%l:%M %P',
      day: '(%e. %b) %l:%M %P',
    }
}