我正在尝试使用js,jquery,nvd3等制作网页...因为它们是很多库和脚本文件我决定浏览网页并寻找以正确顺序加载它们的方法因为没有任何依赖性错误。
我发现这个代码与大多数浏览器兼容,理论上应该可行。显然它可以正常工作,因为脚本列在Chrome的网络标签中,并且控制台没有显示任何内容(除了我期望的消息),但网络没有按预期执行:
function addEvent(element, event, fn) {
if (element.addEventListener) {
element.addEventListener(event, fn, false);
} else if (element.attachEvent) {
element.attachEvent('on' + event, fn);
}
}
function loadScript(src, callback)
{
console.log("cargando");
var s,
r,
t,
write;
write = src.split("/");
// this is useless. It's just for an animation
//document.getElementById('loadingContent').innerHTML = 'Loading ... ' + write[(write.length - 1)] + ' ... ';
r = false;
s = document.createElement('script');
s.type = 'text/javascript';
s.src = src;
s.onload = s.onreadystatechange = function() {
if ( !r && (!this.readyState || this.readyState == 'complete') )
{
r = true;
if (callback !== undefined) {
callback();
}
}
};
t = document.getElementsByTagName('script')[0];
t.parentNode.insertBefore(s, t);
}
addEvent(window, 'load', function(){ loadScript(
'http://ajax.googleapis.com/ajax/libs/jquery/1.11.2/jquery.min.js',
function () {
loadScript('https://cdnjs.cloudflare.com/ajax/libs/d3/3.5.3/d3.min.js',
function () {
loadScript('https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.1.15-beta/nv.d3.min.js',
function() {
loadScript('/static/js/jquery-ui.min.js'),
function() {
loadScript('/static/js/chart.js');
};
});
});
});
});
function mensaje() {
console.log("LOADED");
}
mensaje()
我看到的最奇怪的事情之一就是最后一个函数(“mensage”one)打印它的控制台日志,尽管它是最后一个!
这是我的html代码(“奇怪”的东西是django标签)。我没有任何理由离开了css文件(可能只要我能完成这项工作,我就会将它们包含在加载脚本中):
{% extends "pvpc/base.html" %}
{% block title %}<title>Consumo</title>{% endblock %}
{% load staticfiles %}
{% block scripts %}
<script src="https://cdnjs.cloudflare.com/ajax/libs/nvd3/1.1.15-beta/nv.d3.min.css" charset="utf-8"></script>
<link rel="stylesheet" href="{% static "css/jquery-ui.min.css" %}">
<script src="{% static "js/load_plus.js" %}"></script>
{% endblock %}
{% block header %}<h1>CONSUMO</h1>{% endblock %}
{% block section %}
</head>
<body>
<form>
<div id="radio">
<input type="radio" id="radio1" name="radio" value="1"><label for="radio1">2.0A</label>
<input type="radio" id="radio2" name="radio" value="2"><label for="radio2">2.0DHA</label> <!-- <input checked="checked"> -->
<input type="radio" id="radio3" name="radio" value="3"><label for="radio3">2.0DHS</label>
</div>
</form>
<p>
<label for="amount">Periodo horario:</label>
<input type="text" id="amount" readonly style="border:0; color:#f6931f; font-weight:bold;">
</p>
<p id="slider"></p>
<label for="date">Date</label>
<input type="text" id="date" name="Fecha">
<div id="piechart"><svg></svg></div>
<div id="chart"><svg></svg></div>
</body>
</html>
{% endblock section %}
我真的迷失了,因为我尝试了evrything但却找不到错误...... 我认为它必须是一些让一切都无法发挥作用的小事。
答案 0 :(得分:1)
我认为您希望在加载所有内容时调用mensaje
函数,因此您需要在charts.js行上调用它,如下所示:
loadScript('/static/js/chart.js', mensaje);
(而不是原始代码)。
并且您要删除脚本末尾的行mensaje()
,因为它会调用mensaje
并显示“已加载”#39}。在一切都装满之前。
答案 1 :(得分:0)
js资源可能是您的浏览器缓存的。使用Ctrl + F5重新加载是刷新缓存。在浏览器中打开您的每个js文件,然后按ctrl+F5
刷新该页面。它应该工作。