闭包--打车问题

本文通过一个打车计费的实例,深入浅出地介绍了JavaScript中闭包的概念及应用。通过创建一个闭包,实现了对打车价格计算逻辑的封装,包括起步价和后续每公里费用的累加,并考虑了拥堵附加费。同时,探讨了闭包中this关键字的指向问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

闭包–打车问题
问题:打车起步价13元(三公里以内),之后每多一公里加五块钱。用户输入公里数就可以知道打车的价格。如果有拥挤的情况,总价格多收取10元。

var car = (function(){
        var strart=13;
        var total=0;
        return{
        //返回了两个函数用car来接收
               price:function(n){
                  if(n<=3){
                     total=start;
                  }else{
                     total = strat+(n-3)*5;
                     }
                     return total;
                },
                yd: function(flag){
                     return flag? total+10:total;
                     }
                }
         })();
         console.log(car.price(5));//23
         console.log(car.yd(true));//33

关于function()()

就是第一个括号是函数,第二个是调用
(function(){})()定义了一个匿名函数,相当于先定义 function xx(){},然后调用 xx();
()是最高优先级的,所以先执行function(){},相当于xx=function(){},接着就是调用xx()了。

给个例子:
function f1(a)
{
alert(a);
}
function f2(a)
{
return function(){ alert(a); }
}
var x=f2 相当于把函数传递给了f2,然后要执行这个函数,就必须加(),也就是x(),也就是f2()。
还是
var x=(function f2(a){
return function(){
alert(a);
})();

看到的两个思考题

var name="the window";
var object = {
    name:"my object"
    getNameFunc: function(){
           return funnction(){
                return this.name;
                };
           }
     };
 console.log(object,getNameFunc()())
     //拆解成
     var f = object.getNameFunc();
      //相当于
     var f =function(){
         return this.name;
         }
     f();
     //关键就是看this指向的是谁
     function(){this}();//输出the window,没有闭包

看这个

var name="the window";
var object = {
    name:"my object"
    getNameFunc: function(){
           var that=this;
           //this这里指向的是函数的调用者,即object
           return funnction(){
                return that.name;
                };
           }
     };
 console.log(**object,getNameFunc()**())
//
var f = **object.getName();**
var f = function(){
        return that.name;
        };//相当于返回值
f();
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值