var、let、const的区别,已经作用范围。

在es5中一般经常使用的变量有两个级别,一个是用var声明的全局级别的变量,另外一个是函数级别是用var生命在函数内的。本文中将详细讲解我对es6中的const和let的区别。

let的使用以及作用范围

let是块级变量,只有在自己声明的内部才会有作用。

‘use strict‘;
{
    var a = 12;
    let b = 15;
    {
        console.log(a, b)//12 15没有问题的。
    }
}
console.log(a,b)  //12  defined     a是全局变量在哪里输出都没有问题,然而b是块级变量所以只有在声明b的内部才会有效。

let的提升。下列代码中证明了let没有被提升 var 被提升了。

‘use strict‘;
function fun() {
    // var a   相当于a提升到了这里定义了,但是未赋值。
    console.log(a, b); //undefined defined  注意a是没有被复制,而b是未定义,这说明a是向上提升了而b却没有提升。
    // a = 12; a相当于在这里赋值了、
    var a =  12;
    let b = ‘b‘;
}
fun();

let的提升以及作用范围。

‘use strict‘;
var a = 12;
function f() {
    console.log(a); //defined  因为在函数外部声明了a,然后在函数内部又声明了a,此时函数外部的a就会失效,但是函数内部的a又没有提升的功能所以会输出未定义;
    let a = 100;
}
f();

使用let代替匿名函数立即执行

‘use strict‘;
(function () {
    var config = [];
    config.push(1);
    config.push(2);
    config.push(3);
    console.log(config) //1, 2, 3
})();
let configs;
{
    configs = [];
    configs.push(4);
    configs.push(5);
    configs.push(6);
    console.log(configs) //4, 5, 6
}

const的使用

const是常数顾名思义,就是声明后无法修改的。请看下面的例子。

const的提升和作用范围和let几乎一样,在这里就不做过多的例了。

‘use strict‘;
const a = {
    name: ‘铅笔‘
};
a = 100; //此时会报错

常量不代表所以得东西不能修改,除了a = 这个指向不能修改 a对象内部的属性和值都是可以修改的。

‘use strict‘;
const a = {
    name: ‘铅笔‘
};
a.name = ‘黑白‘;
a.email = ‘[email protected]‘;
console.log(a); // {name : ‘黑白, email : ‘[email protected]‘}

怎么让a和内部的东西不能修改呢?

‘use strict‘;
const a = {
    name: ‘铅笔‘
};
Object.freeze(a);  //a内部的所有属性和值都不能修改了。
a.name = ‘黑白‘;   // 报错
a.email = ‘[email protected]‘; // 报错
console.log(a); // {name : ‘黑白, email : ‘[email protected]‘}
时间: 2024-08-25 01:41:37

var、let、const的区别,已经作用范围。的相关文章

var let const 的区别

Var let const 的区别 1.Var 定义的变量存在变量提升,而了let和const不存在变量提升.即在定义的变量代码上使用该变量,var的会输出undefined,而let的会报错. 2.var不存在暂时性死区,而let存在,只要块级作用域内存在let,它所声明的变量就绑定了这个区域,不在受外部的影响 例如:var tem=123: if(true){ tem='abc';   //报错 ReferenceError,因为在if里声明了let,形成了自己的作用域,外部的访问不到,所以

ES6中var/let/const的区别

最近无聊看了一下前端面试题,看到不少地方要求列出var/let/const的异同,自己整理一下,算加深一下记忆. 1.作用域 var为全局作用域,而let和const为局部作用域(仅作用在大括号内),举个简单例子: 1 if(true){ 2 var a = 1 3 let b = 2 4 const c = 3 5 } 6 console.log(a) //a打印出来为 1 7 console.log(b) //b is not defined 8 console.log(c) //c is

let、var、const的区别

先看let和var: 1. console.log(a); // undefined var a = 3; console.log(a); // Uncaught ReferenceError: Cannot access 'a' before initialization let a = 3; 在当前代码执行之前,首先会把所有带var关键字的进行声明(带function关键字的也会提前声明并且定义),即所谓的变量提升,let则不存在这种情况. ps:项目中创建函数,一般都是基于函数表达式来实现

var let const的区别

1. 变量提升: 浏览器在运行代码之前会进行预解析,不论var声明的变量处于当前作用域的第几行,都会提升到作用域的头部. 2. 只要块级作用域内存在let命令,它所声明的变量就“绑定”这个区域,不再受外部的影响. 3. let不允许在相同作用域内,重复声明同一个变量.  var a = 10;              let a = 6; var a = 20;              let a = 8;  console.log(a);//20        console.log(b)

【vue】var/let/const的区别

var 声明变量 没有区级作用域 可以预解析 可以重复定义 声明的全局变量属于顶层对象(window)的属性 let 声明变量 有块级作用域 没有预解析 不可以重复定义 声明的全局变量不属于顶层对象(window)的属性 const 声明只读常量 ,一旦声明不可更改 有区级作用域 没有预解析 不可以重复定义 定义时就必须赋值否则就报错 声明的全局变量不属于顶层对象(window)的属性 原文地址:https://www.cnblogs.com/websmile/p/11527621.html

var const let 区别

var  const   let  区别 今天第一次遇到const定义的变量,查阅了相关资料整理了这篇文章.主要内容是:js中三种定义变量的方式const, var, let的区别. 1. const 定义的变量是不可修改的,而且必须初始化. 1 const b = 2;//正确 2 // const b;//错误,必须初始化 3 console.log('函数外const定义b:' + b);//有输出值 4 // b = 5; 5 // console.log('函数外修改const定义b:

javascript精雕细琢(一):var let const function声明的区别

目录 引言 一.var 二.let 三.const 四.function 五.总结 引言 在学习javascript的过程中,变量是无时无刻不在使用的.那么相对应的,变量声明方法也如是.变量是由自己决定,但变量声明方法是早已经定义好的.那么在使用变量之前,了解变量声明方法,就变得尤为重要.在ES6推出之前,最常用的声明变量方法就是var.但是由于var自身的缺陷,ES6推出了let和const替代var.虽然修正了var的缺陷,但不能改变的,是之前已经用var写了多少年的项目,这些项目是无法随着

var、const、let 的区别

定义变量的三种方式 var.const.let 都可以用来定义变量,但三者之间存在区别. var var 声明变量的时候无需初始化. var 声明的变量可在后面进行修改. var 声明的全局变量可以被函数修改. <!DOCTYPE html> <html> <head> <title></title> </head> <body> <script type="text/javascript">

ES6和ES5变量声明的区别(var let const)

// es5的语法与es6的语法区别 // var let const console.log(name);//undefine,不会报错,因为变量声明会提到作用域的最前面 var name="aa"; for(var i=1;i<7;i++){ console.log(i); } console.log(i);//8,不会报错因为var声明的变量没有块级作用域 /** * 总结 var 声明的变量,声明语句会提到作用域的最前面,并且没有块级作用域 */ console.log(