理解闭包概念 常见的闭包函数的写法

理解闭包的概念 以及常见的闭包函数的写法

闭包的定义

  • 在程序员的红宝书中,给闭包定义为闭包是指有权访问另一个函数作用域中的变量的函数.相当于父级作用域能够访问子级作用域

闭包的作用

  • 可以在函数的外部访问到函数内部的局部变量。
  • 让这些变量始终保存在内存中,不会随着函数的结束而自动销毁。
  • 能够简化我们的代码量
  • 闭包只能够取得包含函数中任何变量的最后的一个值

举个例子

  • 闭包是可以在另一个函数的外部访问到其作用域中的变量的函数。而被访问的变量可以和函数一同存在。即使另一个函数已经运行结束,导致创建变量的环境销毁,也依然会存在,直到访问变量的那个函数被销毁。当然,如果仅仅是做一个简单的计数器,大可不用这样麻烦。下面这简短的代码就能轻松实现。

var a = 0;
function myFunction(){
     
	a++;
    document.getElementById("demo").innerHTML = a;
}
myFunction()

再举个例子

 //闭包应用 - 计算打车价格
        //打车起步13(3公里内),之后每多一公里增加五块钱,用户输入公里数可以计算打车价格
        //如果有拥堵情况:总价格多收取 10块钱
        var car = (function(){
     
            var start = 13; //起步价 
           var total = 0; //总价
           return {
     
               price:function(kilo){
     
                  if(kilo<=3){
     
                      total = start;
                  }else{
     
                    total = start + (kilo - 3 )*5;
                  }
                  return total;
               },//正常情况下
               yd:function(){
     
                   return flag ? total + 10 :total;
               } //拥堵情况下
           }
        })();
     console.log(car.price(23));   
     console.log('拥堵情况'+car.price());

你可能感兴趣的:(javascript,html5)