• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

【转载】TypeScript学习笔记——var与let

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

var 与  let 都是TypeScript里的变量声明方式

两者非常相似,在语法不存在很大的差异,而在语义上存在很大的区别

 

块作用域

var有着些奇怪的作用域规则

例如

function  f(run: Boolean)
{
         if(run)
         {
               var x=10;               
          }
          return x;
}
 
f(true);   //返回10
f(false);   //返回 undefined

 而 let 的作用域就正常多了

function  f(run: Boolean)
 
{   
 
         let a=1;
         if(run)
         {
               let x=a+1;  
               return x;       //没有错误      
          }
          return x; //错误,x不存在
}

声明

var

多次声明同一个变量,不会报错,只会得到一个变量

function f()
{
    var x;
    var x;
}

上述例子中,所有的x的声明实际上都引用了一个相同的x

这样的声明规则就会造成这样的错误

function f(m : number [ ] [ ] )  
{  
    var sum=0;  
    for (var i=0 ; i<5 ; i++ )  
    {  
         var row = m [ i ] ;  
         for ( var i=0 ; i<5 ; i++ )  
               sun=+ row[ i ];  
    }    
     return sum;    
}

这里返回的sum,并不是这个二维数组的值的总和,原因是里层的for 循环会覆盖变量 i ,所有的 i 都引用相同函数的作用域内的变量。


let
就相对严格,无法多次声明同一个变量,一个变量只能声明一次,并且无法在 let 语句前去访问该变量

function f()
{
     let x;
     let x; //错误 
}

在嵌套作用域中,let 还具有屏蔽功能

function f(m : number [ ] [ ] )
{
    let sum=0;
    for (let i=0 ; i<5 ; i++ )
    {
         let row = m [ i ] ;
         for ( let i=0 ; i<5 ; i++ )
               sun=+ row[ i ];
    }  
     return sum;  
}

这里的得到的sum就是正确答案,因为内层的 i 会屏蔽掉外层的 i 。

通常来讲,我们应该避免使用这个屏蔽功能,这样我们才能写出清晰的代码,但有些情况会需要这种写法

 

原文地址:https://blog.csdn.net/weixin_41962385/article/details/80158246


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
上一篇:
TypeScript--引用数据类型发布时间:2022-07-18
下一篇:
14-TypeScript简单工厂模式发布时间:2022-07-18
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap