1.Var 声明变量

a)存在变量提升

  1. (function(){
  2. var a = "1";
  3. var f = function(){};
  4. var b = "2";
  5. var c = "3";
  6. })();

相当于:

  1. (function(){
  2. var a,f,b,c;
  3. a = "1";
  4. f = function(){};
  5. b = "2";
  6. c = "3";
  7. })();

b)声明多个重复变量,后者覆盖前者

  1. var a = 10;
  2. var a = 20;
  3. var a = 30;
  4. console.log(a) //

c)var声明可以在包含它的函数,模块,命名空间或全局作用域内部任何位置被访问

  1. function f(shouldInitialize) {
  2. if (shouldInitialize) {
  3. var x = 10;
  4. }
  5.  
  6. return x;
  7. }
  8.  
  9. f(true); //
  10. f(false); // undefined

d)作用域问题

  1. function sumMatrix(matrix: number[][]) {
  2. var sum = 0;
  3. for (var i = 0; i < matrix.length; i++) {
  4. var currentRow = matrix[i];
  5. for (var i = 0; i < currentRow.length; i++) {
  6. sum += currentRow[i];
  7. }
  8. }
  9.  
  10. return sum;
  11. }
  12.  
  13. console.log(sumMatrix([[1,2,3],[10,2,3]])) //无论第二个数组怎么改变,结果始终为

e)怪异的变量获取

  1. for (var i = 0; i < 10; i++) {
  2. setTimeout(function() { console.log(i); }, 100 * i);
  3. }
  4. //期望输出结果:0-9
  5. //实际输出结果:10个10

解决方式:

  1. for (var i = 0; i < 10; i++) {
  2. (function(i) {
  3. setTimeout(function() { console.log(i); }, 100 * i);
  4. })(i);
  5. }
  1. for (let i = 0; i < 10; i++) {
  2. setTimeout(function() { console.log(i); }, 100 * i);
  3. }
  1.  

2.let变量声明

a)当用let声明一个变量,它使用的是词法作用域块作用域,在包含它们的块或for循环之外是不能访问的。

  1. function f(input: boolean) {
  2. let a = 100;
  3.  
  4. if (input) {
  5. // Still okay to reference 'a'
  6. let b = a + 1;
  7. return b;
  8. }
  9.  
  10. // Error: 'b' doesn't exist here
  11. return b;
  12. }

b)不能在 let语句之前访问它们

  1. a++; // illegal to use 'a' before it's declared;
  2. let a;

c)同时多次声明同一个变量报错

  1. let x = 10;
  2. let x = 20; // 错误,不能在1个作用域里多次声明`x`

3.const变量声明

与 let相同的作用域规则,但是不能对它们重新赋值。

TS学习之变量声明的更多相关文章

  1. httprunner学习4-variables变量声明与引用

    前言 在 HttpRunner 中,支持变量声明(variables)和引用($var)的机制.在 config 和 test 中均可以通过 variables 关键字定义变量,然后在测试步骤中可以通 ...

  2. linux shell 学习笔记--变量声明与赋值,循环

    Bash 变量是不分类型的 ------------------------ 不像其他程序语言一样,Bash 并不对变量区分"类型".本质上,Bash 变量都是字符串. 但是依赖于 ...

  3. TS学习随笔(七)->声明文件

    now我们来看一看TS怎么声明文件, 在JS里面我们经常会使用各种第三方类库,引入方式也不太相同,常见的就是在HTML中通过script标签引入,然后就可以使用全局变量$或者jQuery了 我们通常这 ...

  4. Typescript学习笔记(三)变量声明及作用域

    ts的变量声明有var,let和const,这尼玛完全跟es6一样嘛.就稍微介绍一下. 大多数js开发者对于var很熟悉了,原生js里没有块级作用域,只有函数作用域和全局作用域,还存在var的变量提升 ...

  5. [Golang学习笔记] 04 程序实体1 变量声明

    变量声明: Go语言的程序实体包含:变量.常量.函数.结构体和接口,是一门静态类型的编程语言. (在声明变量或常量的时候,需要指定类型,或者给予足够信息是的Go语言能够推导出类型) Go语言变量的类型 ...

  6. JavaScript:学习笔记(7)——VAR、LET、CONST三种变量声明的区别

    JavaScript:学习笔记(7)——VAR.LET.CONST三种变量声明的区别 ES2015(ES6)带来了许多闪亮的新功能,自2017年以来,许多JavaScript开发人员已经熟悉并开始使用 ...

  7. ES6学习笔记之变量声明let,const

    最近用淘宝的weex做了个项目,最近稍微闲下来了.正好很久没有接触RN了,所以趁这个机会系统的学习一下ES6的相关知识. 孔子说:没有对比就没有伤害.所以我们要拿ES6和ES5好好对比的学习.这样才能 ...

  8. Fortran学习笔记:01 基本格式与变量声明

    Fortran学习笔记目录 01 基本格式与变量声明 格式 固定格式(Fixed Format):Fortran77 程序需要满足一种特定的格式要求,具体形式参考教材 自由格式(Free Format ...

  9. JavaScript学习01 语言简介、基本使用和变量声明

    JavaScript语言简介.基本使用和变量声明 JavaScript是网景(Netscape)公司开发的一种基于客户端浏览器.面向对象.事件驱动式的网页脚本语言. JavaScript的前身叫Liv ...

随机推荐

  1. cocos2d-x3.6 生成带类图的离线文档

    我的博客:http://blog.csdn.net/dawn_moon cocos2d-x的官网有点慢,并且最新3.6的在线API文档居然没有了类图,不知道什么原因,之前2.2.6都是有的. 只是能够 ...

  2. SQL2000 3核6核 CUP 安装SP4

    1.找到HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432node\Microsoft\MSSQLServer \MSSQLServer\Parameters\ 2.然后加入下面的 ...

  3. activiti--4----------------------------------流程变量

    一.流程变量的作用 1.用来传递业务参数 2.指定连线完成任务(同意或拒绝) 3.动态指定任务办理人 二.测试代码块 Person类 package com.xingshang.processVari ...

  4. 通过systemd配置Docker

    1. systemd Service相关目录 通常情况下,我们有3种方式可以配置etcd中的service.以docker为例,1)在目录/etc/systemd/system/docker.serv ...

  5. Hadoop如何修改HDFS文件存储块大小

    一. 临时修改可以在执行上传文件命令时,显示地指定存储的块大小.1. 查看当前 HDFS文件块大小我这里查看HDFS上的TEST目录下的jdk-7u25-linux-x64.gz  文件存储块大小.1 ...

  6. 326 集合 ,数据类型的补充 ,copy , 编码之间的转换

    一.数据类型补充1,对于元组:如果只有一个元素,并且没有逗号,此元素是什么数据类型,改表达式就是什么数据类型. tu = () tu1 = (,) print(tu,type(tu)) #1 < ...

  7. Python 3 面向对象 一

    Python 3 面向对象 一.面向过程-->面向对象 面向过程:根据业务逻辑从上到下堆叠代码,即先干什么再干什么,基于面向过程去设计程序就好比在设计一条流水线,是一种机械式的思维方式 函数式: ...

  8. Spring层面的事务管理

    事务管理方式 1. 编程式事务管理 2. 声明式事务管理 建立于AOP之上,对指定的方法执行前后进行拦截,即在方法执行前开始或加入一个事务,执行完毕后根据结果提交或回滚事务. 方式: a. 配置文件中 ...

  9. China sets economic reform priorities for 2015

    BEIJING -- China's State Council, the cabinet, on Monday unveiled this year's priorities for economi ...

  10. java入门了解15

    1.批处理文件(bat) 简单的说,批处理的作用就是自动的连续执行多条命令 .编写bat处理文件可以使用记事本的方式: 常见批处理文件的命令: echo 表示显示此命令后的字符 tiltle 设置窗口 ...