TS学习之变量声明
1.Var 声明变量
a)存在变量提升
- (function(){
- var a = "1";
- var f = function(){};
- var b = "2";
- var c = "3";
- })();
相当于:
- (function(){
- var a,f,b,c;
- a = "1";
- f = function(){};
- b = "2";
- c = "3";
- })();
b)声明多个重复变量,后者覆盖前者
- var a = 10;
- var a = 20;
- var a = 30;
- console.log(a) //
c)var
声明可以在包含它的函数,模块,命名空间或全局作用域内部任何位置被访问
- function f(shouldInitialize) {
- if (shouldInitialize) {
- var x = 10;
- }
- return x;
- }
- f(true); //
- f(false); // undefined
d)作用域问题
- function sumMatrix(matrix: number[][]) {
- var sum = 0;
- for (var i = 0; i < matrix.length; i++) {
- var currentRow = matrix[i];
- for (var i = 0; i < currentRow.length; i++) {
- sum += currentRow[i];
- }
- }
- return sum;
- }
- console.log(sumMatrix([[1,2,3],[10,2,3]])) //无论第二个数组怎么改变,结果始终为
e)怪异的变量获取
- for (var i = 0; i < 10; i++) {
- setTimeout(function() { console.log(i); }, 100 * i);
- }
- //期望输出结果:0-9
- //实际输出结果:10个10
解决方式:
- for (var i = 0; i < 10; i++) {
- (function(i) {
- setTimeout(function() { console.log(i); }, 100 * i);
- })(i);
- }
- for (let i = 0; i < 10; i++) {
- setTimeout(function() { console.log(i); }, 100 * i);
- }
2.let变量声明
a)当用let
声明一个变量,它使用的是词法作用域或块作用域,在包含它们的块或for
循环之外是不能访问的。
- function f(input: boolean) {
- let a = 100;
- if (input) {
- // Still okay to reference 'a'
- let b = a + 1;
- return b;
- }
- // Error: 'b' doesn't exist here
- return b;
- }
b)不能在 let
语句之前访问它们
- a++; // illegal to use 'a' before it's declared;
- let a;
c)同时多次声明同一个变量报错
- let x = 10;
- let x = 20; // 错误,不能在1个作用域里多次声明`x`
3.const变量声明
与 let
相同的作用域规则,但是不能对它们重新赋值。
TS学习之变量声明的更多相关文章
- httprunner学习4-variables变量声明与引用
前言 在 HttpRunner 中,支持变量声明(variables)和引用($var)的机制.在 config 和 test 中均可以通过 variables 关键字定义变量,然后在测试步骤中可以通 ...
- linux shell 学习笔记--变量声明与赋值,循环
Bash 变量是不分类型的 ------------------------ 不像其他程序语言一样,Bash 并不对变量区分"类型".本质上,Bash 变量都是字符串. 但是依赖于 ...
- TS学习随笔(七)->声明文件
now我们来看一看TS怎么声明文件, 在JS里面我们经常会使用各种第三方类库,引入方式也不太相同,常见的就是在HTML中通过script标签引入,然后就可以使用全局变量$或者jQuery了 我们通常这 ...
- Typescript学习笔记(三)变量声明及作用域
ts的变量声明有var,let和const,这尼玛完全跟es6一样嘛.就稍微介绍一下. 大多数js开发者对于var很熟悉了,原生js里没有块级作用域,只有函数作用域和全局作用域,还存在var的变量提升 ...
- [Golang学习笔记] 04 程序实体1 变量声明
变量声明: Go语言的程序实体包含:变量.常量.函数.结构体和接口,是一门静态类型的编程语言. (在声明变量或常量的时候,需要指定类型,或者给予足够信息是的Go语言能够推导出类型) Go语言变量的类型 ...
- JavaScript:学习笔记(7)——VAR、LET、CONST三种变量声明的区别
JavaScript:学习笔记(7)——VAR.LET.CONST三种变量声明的区别 ES2015(ES6)带来了许多闪亮的新功能,自2017年以来,许多JavaScript开发人员已经熟悉并开始使用 ...
- ES6学习笔记之变量声明let,const
最近用淘宝的weex做了个项目,最近稍微闲下来了.正好很久没有接触RN了,所以趁这个机会系统的学习一下ES6的相关知识. 孔子说:没有对比就没有伤害.所以我们要拿ES6和ES5好好对比的学习.这样才能 ...
- Fortran学习笔记:01 基本格式与变量声明
Fortran学习笔记目录 01 基本格式与变量声明 格式 固定格式(Fixed Format):Fortran77 程序需要满足一种特定的格式要求,具体形式参考教材 自由格式(Free Format ...
- JavaScript学习01 语言简介、基本使用和变量声明
JavaScript语言简介.基本使用和变量声明 JavaScript是网景(Netscape)公司开发的一种基于客户端浏览器.面向对象.事件驱动式的网页脚本语言. JavaScript的前身叫Liv ...
随机推荐
- cocos2d-x3.6 生成带类图的离线文档
我的博客:http://blog.csdn.net/dawn_moon cocos2d-x的官网有点慢,并且最新3.6的在线API文档居然没有了类图,不知道什么原因,之前2.2.6都是有的. 只是能够 ...
- SQL2000 3核6核 CUP 安装SP4
1.找到HKEY_LOCAL_MACHINE\SOFTWARE\WOW6432node\Microsoft\MSSQLServer \MSSQLServer\Parameters\ 2.然后加入下面的 ...
- activiti--4----------------------------------流程变量
一.流程变量的作用 1.用来传递业务参数 2.指定连线完成任务(同意或拒绝) 3.动态指定任务办理人 二.测试代码块 Person类 package com.xingshang.processVari ...
- 通过systemd配置Docker
1. systemd Service相关目录 通常情况下,我们有3种方式可以配置etcd中的service.以docker为例,1)在目录/etc/systemd/system/docker.serv ...
- Hadoop如何修改HDFS文件存储块大小
一. 临时修改可以在执行上传文件命令时,显示地指定存储的块大小.1. 查看当前 HDFS文件块大小我这里查看HDFS上的TEST目录下的jdk-7u25-linux-x64.gz 文件存储块大小.1 ...
- 326 集合 ,数据类型的补充 ,copy , 编码之间的转换
一.数据类型补充1,对于元组:如果只有一个元素,并且没有逗号,此元素是什么数据类型,改表达式就是什么数据类型. tu = () tu1 = (,) print(tu,type(tu)) #1 < ...
- Python 3 面向对象 一
Python 3 面向对象 一.面向过程-->面向对象 面向过程:根据业务逻辑从上到下堆叠代码,即先干什么再干什么,基于面向过程去设计程序就好比在设计一条流水线,是一种机械式的思维方式 函数式: ...
- Spring层面的事务管理
事务管理方式 1. 编程式事务管理 2. 声明式事务管理 建立于AOP之上,对指定的方法执行前后进行拦截,即在方法执行前开始或加入一个事务,执行完毕后根据结果提交或回滚事务. 方式: a. 配置文件中 ...
- China sets economic reform priorities for 2015
BEIJING -- China's State Council, the cabinet, on Monday unveiled this year's priorities for economi ...
- java入门了解15
1.批处理文件(bat) 简单的说,批处理的作用就是自动的连续执行多条命令 .编写bat处理文件可以使用记事本的方式: 常见批处理文件的命令: echo 表示显示此命令后的字符 tiltle 设置窗口 ...