定义定义定义惰性载入函数表示函数执行的分支仅会发生一次,有两种实现惰性载入函数的方式,第一种是在函数被调用时再处理,在第一次调用中,该函数会覆盖为另外一个按合适方式执行的函数,这样任何对函数的调用都不用再经过执行的分支了。第二种实现惰性载入的方式是在声明函数时就制定适当的函数,这样,第一次调用函数时就不会损失性能了,而在代码首次加载时会损失一点儿性能。功能功能功能由于现在浏览器之间的差异,为了实现跨浏览器工作,很多函数要书写大量if语句或者try…catch…语句。当每次调用函数时,都要对每个if分支或try语句进行检查,这样会使得浏览器反应变慢。实际上,当我们用某个浏览器打开网页时,就决定了某个if分支或try语句是可用的,没有必要每次调用都检查。为了解决以上问题,JavaScript中出现一种名为惰性载入的技巧。示例示例示例载入方式一载入方式一
var flag = 1;
function test1() {
if(typeof flag === 'undefined') {
test1 = function() {

return 0;
}
} else if(flag === 1) {
test1 = function() {

return 1;
}
} else {
test1 = function () {

return -1;
}
}
return test1();
}
var flag = 1;
function test1() {
if(typeof flag === 'undefined') {
test1 = function() {

return 0;
}
} else if(flag === 1) {
test1 = function() {

return 1;
}
} else {
test1 = function () {

return -1;
}
}
return test1();
}这里if语句的每个分支都会为test1变量赋值,有效覆盖了原有的函数,最后一步便是调用新赋的函数,下一次调用test1()的时候就会直接调用被分配的函数,就不会再走if语句了,这样就可以提高性能。载入方式二载入方式二
var flag = 1;
var test2 = (function() {
if(typeof flag === 'undefined') {
return function() {

return 0;
}
} else if(flag === 1) {
return function () {

return 1;
}
} else {
return function () {

return -1;
}
}
})();
var flag = 1;
var test2 = (function() {
if(typeof flag === 'undefined') {
return function() {

return 0;
}
} else if(flag === 1) {
return function () {

return 1;
}
} else {
return function () {

return -1;
}
}
})();不同点是使用了立即执行函数,通过var来定义函数,在每个if分支中return一个函数。优势优势优势惰性载入函数有两个主要优点,第一是显而易见的效率问题,虽然在第一次执行的时候函数会意味赋值而执行的慢一些,但是后续的调用会因为避免的重复检测更快;第二个是要执行的适当代码只有当实际调用函数是才执行,很多JavaScript库在在加载的时候就根据浏览器不同而执行很多分支,把所有东西实现设置好,而惰性载入函数将计算延迟,不影响初始脚本的执行时间。总结总结总结以上所述是小编给大家介绍的JavaScript中的惰性载入函数及优势,希望对大家有所帮助,也非常感谢大家对网站的支持!