博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
JavaScript变量声明
阅读量:6213 次
发布时间:2019-06-21

本文共 1003 字,大约阅读时间需要 3 分钟。

const,let,var的区别和用法

1.const——声明一个只读的常量,在声明的时候给其赋初值,之后不能再进行赋值。

1 const i = 0;2 console.log(i);    //有输出,为0

如果对 i 进行再次赋值则会报错,TypeError:Assignment to constant variable

1 const i = 0;2 i = 5;3 console.log(i);    //无输出,报错

2.var——用于声明变量,声明在方法外则为全局变量,在方法内则为局部变量,只能在方法内读取。

1 var i;2 console.log(i);    //如果不赋初值,输出为undefined

如果声明变量时没有使用 var 关键字,则该变量一定为全局变量。到那时在调用的时候有以下区别:

如果时声明在方法外的全局变量,在方法内可以直接使用;如果该全局变量时声明在方法内部的,则在方法外使用该变量时需要先调用方法,告知系统声明了全局变量才能使用。

需要特别注意的问题:没有使用 var 关键字定义的全局变量没有预编译过程,所以如果把变量的使用放在定义之前则会报错。

1 alter(i);  //  i is not defined    2 i = 1;

3.let——块级作用域,方法内部使用 let 定义后对方法外没有影响。

let 时ES6新增的变量声明命令,作用就是声明一个局部变量。

1 var a = [];2 for(var i=0;i < 10;i++){3 //循环内的计数变量 i 使用var定义为全局变量,所以循环过程中会不断地对值进行覆盖4    a[i] = function (){5       console.log(i);6    }  7 }8 a[6]();    //最后的输出是 10
var a = [];for(let i=0;i < 10;i++){//这里的 i 使用let定义为局部变量,就是只在当前循环生效,所以每次进行循环的 i 都是新的变量,值不会进行覆盖    a[i] = function(){        console.log(i);    }}a[6]();  //最后的输出是 6

 

转载于:https://www.cnblogs.com/edward-life/p/11052069.html

你可能感兴趣的文章
浅谈 Object.observe
查看>>
mysqld服务器系统变量和状态变量
查看>>
自己动手写计算器v1.1
查看>>
程序进程逐步显示,并可以控制停止和继续以及跳转
查看>>
codevs2894、2837、1669、2503、3231
查看>>
HashMap和Hashtable的区别
查看>>
Extjs 分页实例 后台php
查看>>
用MathType编辑反三角函数的方法
查看>>
TVS管性能及选型总结
查看>>
【Go语言】错误与异常处理机制
查看>>
判断数组有哪些方法
查看>>
Firefox 在LR录制过程中添加例外的问题解决方法
查看>>
quartz表达式
查看>>
对空类型求sizeof
查看>>
购物车 python作业
查看>>
Nodejs与ES6系列4:ES6中的类
查看>>
邻接表 - 边表
查看>>
linux下源码安装rabbitMq
查看>>
分布式事务解决方案(转载+整理)
查看>>
SSE(Server-sent events)技术在web端消息推送和实时聊天中的使用
查看>>