我想做一个使用js,jquery,nvd3等的网络......因为他们是很多的图书馆和脚本文件,我决定冲浪网站和寻找一种以正确的顺序加载它们的方法,以免出现任何依赖性错误。Js,jquery和其他脚本加载,但不能工作
我发现这个代码与大多数浏览器兼容,理论上应该可以工作。显然它工作正常,因为脚本被列为加载在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”)打印出控制台日志,尽管是最后一个!
这里是我的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但不容找到错误... 我认为它必须是一些小事情,使一切不工作。
_“但网络没有做到预期的事情”_不描述你的实际问题是什么,什么是不工作? –
基本上没什么,如果我知道你不认为我会修好它吗? – XcodeX
如果你不知道什么不工作,你怎么知道它已经坏了?例如,脚本没有执行,或脚本中创建的对象不可访问(即,您不能使用jQuery对象) –