好吧所以我自己做了一个小对象来评估整个加载jquery的回退事情(并使用它来加载所有我的js文件,infact),使用JSON:
<script type="text/javascript">
/* Library loading object */
var ScriptLoader = {
//values
head_tag : document.getElementsByTagName('head')[0],
fallback : false,
//functions
createScript: function(script_path) {
var script_tag = document.createElement('script');
script_tag.type = 'text/javascript';
script_tag.src = script_path;
return script_tag;
},
addToHead : function(tag) {
ScriptLoader.head_tag.appendChild(tag);
},
addLoadEvent : function(func) {
var prev = window.onload;
if (typeof window.onload !== 'function') {
window.onload = func;
} else {
window.onload = function() {
prev();
func();
}
}
}
};
//Loading jquery, modernizr, and my js files when window is ready.
ScriptLoader.addLoadEvent(function() {
/* Load from jquery's cdn for speed + auto latest download */
var scripts = ['http://code.jquery.com/jquery-latest.min.js',
'scripts/modernizr.js',
'scripts/script.js'],
idx = 0;
for (; idx < scripts.length; idx++) {
ScriptLoader.addToHead(ScriptLoader.createScript(scripts[idx]));
}
});
//jquery fallback
ScriptLoader.addLoadEvent(function() {
if (typeof window.jQuery === undefined) {
ScriptLoader.fallback = true;
ScriptLoader.addToHead(ScriptLoader.createScript('scripts/jquery-mini-1.6.2.js'));
}
});
//grab info
(function() {
setTimeout(function() {
console.log('jquery loaded: ' + (window.jQuery !== undefined));
console.log('used fallback: ' + ScriptLoader.fallback);
}, 1000);
})();
现在,这完全正常,但请注意对我的对象名称的不断调用?有没有办法简单地使用 this 而不是那个?我只得到了整个功能级范围的东西,并且还意识到这被分配到最近的封闭函数,但我不是很清楚......
我也很简单地阅读,但没有完全理解封闭..
谢谢:)
答案 0 :(得分:0)
否,因为this
引用了对象的实例,而不是对象模板。
闭包只是从函数内返回函数,然后可以将它们分配给新变量并像执行父函数一样执行。即使没有通过新的赋值提及它,闭包仍保留其原始函数父的范围。这就是闭包容易发生内存泄漏的原因,因为ECMAScript的垃圾收集器没有封闭分配的范围。
function foo(a,b){
var c = 1;
return function(c){
return a + b + c;
}
}
var bar = foo(3,5); // bar is now a closure
alert(bar(2)); // 10