首页 > 解决方案 > 使用异步属性时 Javascript 不起作用:Highcharts

问题描述

我正在尝试加快我的页面速度。但问题是我认为 Highcharts js 可能会减慢我的网站速度。

我在标题中包含了 Highchart 的 JS,因为我需要更早地执行脚本,以便可以加载 highchart 的地图。但我认为这个过程非常影响我的Pagespeed

我被要求延迟解析js,所以我所做的是我在脚本标签中添加了一个异步属性,但是在添加了异步属性之后我的地图停止显示。

我的脚本标签是这样的。

<script async src="assets/js/jquery.min.js"></script>
<script async src="assets/js/script.min.js"></script>
<script async type="text/javascript" src="assets/js/jquery-3.3.1.js"></script>
<script async src="js/highcharts/highstocks.js"></script>
<script async src="js/highcharts/mapmodulesdata.js"></script>
<script async src="js/highcharts/mapmodulesexporting.js"></script>
<script async src="js/highcharts/map-export-data.js"></script>
<script async src="js/highcharts/map.js"></script>
<script async src="js/highcharts/worldmap.js"></script>

如果我遗漏了什么,请纠正我

标签: javascriptasynchronoushighchartsgoogle-pagespeed

解决方案


只有在 dom 中加载了“highcharts.js”后才需要调用 Highcharts API,可以按照以下示例进行操作:

https://codepen.io/anon/pen/ydorpE?&editable=true

  var script =   document.getElementById("script1");  

script.onload = function(){ 
afterLoad()
}



function afterLoad () {
  Highcharts.chart('container', {

  title: {
    text: 'Solar Employment Growth by Sector, 2010-2016'
  },

  subtitle: {
    text: 'Source: thesolarfoundation.com'
  },

  yAxis: {
    title: {
      text: 'Number of Employees'
    }
  },
  legend: {
    layout: 'vertical',
    align: 'right',
    verticalAlign: 'middle'
  },

  plotOptions: {
    series: {
      label: {
        connectorAllowed: false
      },
      pointStart: 2010
    }
  },

  series: [{
    name: 'Installation',
    data: [43934, 52503, 57177, 69658, 97031, 119931, 137133, 154175]
  }, {
    name: 'Manufacturing',
    data: [24916, 24064, 29742, 29851, 32490, 30282, 38121, 40434]
  }, {
    name: 'Sales & Distribution',
    data: [11744, 17722, 16005, 19771, 20185, 24377, 32147, 39387]
  }, {
    name: 'Project Development',
    data: [null, null, 7988, 12169, 15112, 22452, 34400, 34227]
  }, {
    name: 'Other',
    data: [12908, 5948, 8105, 11248, 8989, 11816, 18274, 18111]
  }],

  responsive: {
    rules: [{
      condition: {
        maxWidth: 500
      },
      chartOptions: {
        legend: {
          layout: 'horizontal',
          align: 'center',
          verticalAlign: 'bottom'
        }
      }
    }]
  }

});

  
}
#container {
  min-width: 310px;
  max-width: 800px;
  height: 400px;
  margin: 0 auto
}
<script id='script1' async   src="https://code.highcharts.com/highcharts.js"></script>
<script async src="https://code.highcharts.com/modules/series-label.js"></script>
<script async src="https://code.highcharts.com/modules/exporting.js"></script>
<script async src="https://code.highcharts.com/modules/export-data.js"></script>

<div id="container"></div>


推荐阅读