javascript - 使用异步属性时 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>
如果我遗漏了什么,请纠正我
解决方案
只有在 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>
推荐阅读
- javascript - 如何将选项从 HTML 传递给 izimodal (JS)
- esp32 - 如何为 ESP32-SOLO-1 配置 PlatformIO?
- python - 如何获得与 index1 相关的 index2 的总和
- c++11 - 在 MLpack 中使用距离度量
- r - 传播/收集错误:必须提供符号或字符串作为参数
- wsdl - 通过 BluePrism 使用 SOAP 和 Base64 将附件上传到 ServiceNow
- android-studio - Kotlin 中的关键字 object 是什么意思?
- mysql - 有多少产品有多个价格?不要重复计算相同的产品
- javascript - React 添加一个变量名属性
- r - 如何计算子集的时间间隔?