首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往
您找到你想要的搜索结果了吗?
是的
没有找到

Js中var let const 区别

一、前言 在ES6(ES2015)出现之前,JavaScript中声明变量就只有通过 var 关键字,函数声明是通过 function 关键字,而在ES6之后,声明的方式有 var 、 let 、 const...二、var 如果使用关键字 var 声明变量,那么这个变量就属于当前的函数作用域,如果声明是发生在任何函数外的顶层声明,那么这个变量就属于全局作用域。...举例说明: var a = 1; //此处声明的变量a为全局变量 function foo(){ var a = 2;//此处声明的变量a为函数foo的局部变量 console.log(a)...let 声明的变量,具有如下几个特点: let 声明的变量具有块作用域的特征。...六、总结 var 声明的变量属于函数作用域,let 和 const 声明的变量属于块级作用域; var 存在变量提升现象,而 let 和 const 没有此类现象; var 变量可以重复声明,而在同一个块级作用域

1.7K30

js中var、let、const区别

javascript中有三种声明变量的方式:var、let、const 1.var 作用域:全局或局部 var的作用域可以是全局或是局部,以下分四种情况说明: (1).当var关键字声明于函数内时是局部变量...,此时在函数外访问会报错。...(2)当var关键字声明于函数外时是全局变量,此时不论在函数外部还是内部都可以访问到。...(3)当var关键字第一次声明变量于函数外时是全局变量,并且在函数内又使用var关键字声明了同一名字的变量,那么后声明这个是局部变量只作用于函数内,对函数外第一次声明的变量不影响。...2.let 作用域:局部(块级作用域) let是块级作用域,函数内部使用let定义后,对函数外部无影响,在同一块域内let不可重复声明 3.const 作用域:局部(块级作用域) const定义的变量作为一常量

2.1K20

JS基础】JSLet 和 Const 变量区别

在 JavaScript 中,let 和 const 都是用于声明变量的关键字,但它们之间有一些重要的区别: 可变性: let 允许在声明之后更改变量的值。...这意味着您可以重新为使用 let 声明的变量分配任何类型的值: let x = 1; x = "text"; const 用于声明常量,一旦声明了变量,它的值就不能改变。...这意味着在使用它们声明变量时,变量仅在声明它们的代码块(例如:函数、循环或其他控制结构)中可用。...这与使用 var 声明的变量不同,因为它们具有函数作用域: if (true) { let x = 1; const y = 2; } console.log(x); // ReferenceError...: x is not defined console.log(y); // ReferenceError: y is not defined 变量提升: 在执行代码之前,var 声明的变量会被提升到函数作用域的顶部

17310

【Kotlin】标准库函数 ① ( apply 标准库函数 | let 标准库函数 )

实例对象 ; apply 函数let 函数的区别 : apply 函数的 返回值是 调用者 ; let 函数的 返回值是 Lambda 表达式的最后一行 ; let 函数原型 : /** * 调用以...{ it.capitalize() } println(name) } 上述代码中 , 调用 字符串 “tom” 的 let 函数 , 在 let 函数中 , 将首字母变为大写..., 并返回 , let 函数返回的是 匿名函数 的最后一行 , 因此将 “Tom” 字符串 返回了 ; 如果将 let 函数换成 apply 函数 , 则返回的就是 “tom” 字符串本身 , 不是...let {...} 为空 , 后面的 let 函数根本不会执行 , 此时会取 空合并操作符 ?...: 后面的值作为整个表达式的值 ; 如果 name 不为空 , 则 执行 let 函数 , 整个表达式的值 就是 let 函数的最后一行 返回值 ; 执行结果 : name 为空

1K10

JS底层理解var、let、const

引用数据类型的值是保存在内存中的对象,JS不允许直接访问内存中的位置,所以在操作的时候操作的是对象的引用;因此是引用数据类型是按照引用访问的。...传递参数 参数传递就跟把函数外部的值复制给函数内部的参数; 基本类型传参 function addTen(num) { num+=10; return num; } const count...实际上,在函数内部重写 obj时,这个变量引用的就是一个局部对象了。而这个局部对象会在函数执行完毕之后立即销毁。...name 的定义被提升到了顶部,并在初始化赋值之前是 undefined,所以typeof name == 'undefined' var,let,const 我们先来看看,var,let,const...let b = 2; let 声明的变量可以被修改。

1.8K30

【Kotlin】标准库函数总结 ( apply 函数 | let 函数 | run 函数 | with 函数 | also 函数 | takeIf 函数 | takeUnless 函数 )

实例对象 ; apply 函数let 函数的区别 : apply 函数的 返回值是 调用者 ; let 函数的 返回值是 Lambda 表达式的最后一行 ; let 函数原型 : /** * 调用以..., 并返回 , let 函数返回的是 匿名函数 的最后一行 , 因此将 “Tom” 字符串 返回了 ; 如果将 let 函数换成 apply 函数 , 则返回的就是 “tom” 字符串本身 , 不是...let {...} 为空 , 后面的 let 函数根本不会执行 , 此时会取 空合并操作符 ?...: 后面的值作为整个表达式的值 ; 如果 name 不为空 , 则 执行 let 函数 , 整个表达式的值 就是 let 函数的最后一行 返回值 ; 执行结果 : name 为空 三、run 标准库函数...表达式参数 , 并返回 接收者实例对象本身 ; also 函数let 函数 返回值不同 , also 函数 返回 接收者对象本身 , let 函数 返回 Lambda 表达式的最后一行 ; also

1.7K10

死磕JS:var、let、const 该怎么选?

众所周知,在 Javascript 中就有 3 个关键字可以声明变量,分别是 var,let,const,具体在使用时候我们,怎么选择呢?...var 在 ECMAScript 的所有版本中都可以使用,而 const 和 let 只能在 ECMAScript6 及更晚的版本中使用。 那么这 3 个关键字 都有哪些异同点及注意事项吗?...函数体为 函数作用域, 任意一个 {} 内为一个 块级作用域 var 声明的变量,在函数作用域 中生效,所以只有在函数中声明的变量属于局部变量,在代码块中声明的依然为全局变量。...function test() { var message = 'hi'; // 函数体内声明,为局部变量,函数体外无法引用 console.log(message) // 'hi' }...function test(){ let message = 'hi'; // 函数块中声明,函数体外无法引用 const message1 = 'hello'; // 函数块中声明,函数体外无法引用

1.9K10

js中const,var,let定义变量的区别

js中const,var,let定义变量的区别 1.const定义变量不可以修改,而且必须初始化 const b = 2;//正确 // const b;//错误,必须初始化 console.log...('函数外const定义b:' + b);//有输出值 // b = 5; // console.log('函数外修改const定义b:' + b);//无法输出 2.var定义的变量可以修改...(); console.log('函数调用后var定义a为函数内部修改值:' + a);//可以输出a=4 3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。...let c = 3; console.log('函数let定义c:' + c);//输出c=3 function change(){ let c = 6; console.log...('函数let定义c:' + c);//输出c=6 } change(); console.log('函数调用后let定义c不受函数内部定义影响:' + c);//输出c=3

3.2K30

Kotlin中apply,run,let,also,with函数总结

fun T.run(f: T.() -> R): R = f() let 默认当前这个对象作为闭包的it参数,返回值是函数里面最后一行,或者指定return fun T.let...(f: (T) -> R): R = f(this) let是将当前的函数传入后面的闭包中(it),可以随意指定返回值得类型 是不是意味着可以在let中,对其本身进行操作。...都是在本身的调用方式上,强制返回本身 with with函数是一个单独的函数,并不是Kotlin中的extension,所以调用方式有点不一样,返回是最后一行,然后可以直接调用对象的方法,感觉像是let...//返回值可以自己定义.如果写this,就是和apply一模一样 this } //let的三个点 m.let { //1.调用是需要调用it,...T.also{}和T.let{}其实是一样的。also只是将本身做了强制的返回。 with(T){}和T.run{}其实是一致的。不同之处是,with是单独的函数。 四者目前来看,没有什么不同。

1.4K20

JavaScript(JS)中var和let的区别及推荐

从以下几个方面解释: 作用域:var是函数作用域,而let是块作用域,也就是说,在函数内声明了var,整个函数内都是有效的,比如说在for循环内定义了一个var变量,实际上其在for循环以外也是可以访问的...,而let由于是块作用域,所以如果在块作用域内(比如说for循环内)定义的变量,在其外面是不可被访问的,所以let用在for (let i; i < n; i++)是一种很推荐的写法 let不能在定义之前访问该变量...也就是说,当这个函数的作用域被创建的时候,实际上var定义的变量都会被创建,并且如果此时没有初始化的话,则默认会初始化一个undefined, 补充: var js=function(){} 这种叫做函数表达式...必须先定义后使用 function js(){}这种是函数声明 可以先使用后定义 它会对函数的声明进行一个提升,提升只是相当于提前声明,函数提前声明,在使用的时候不会报错。...所以一般情况下的话,推荐用let,const这些。

1.4K50

JS函数

(){ console.log("hello js") } sayHello() 参数 形式参数 : 在函数声明时, 设置的参数。...//带参数的函数声明 function 函数名(形参1, 形参2, 形参...){ //函数体 } //带参数的函数调用 函数名(实参1, 实参2, 实参3); 计算2个数的和 ...函数作用域 :在 函数内的区域 叫做函数作用域,在函数作用域内声明的变量叫做局部变量 ,局部变量只有在当前函数内才能访问到。...预解析 js执行代码分为两个过程: 预解析过程(变量与函数提升) 代码一行一行执行 console.log(num); var num = 1 console.log(num) 预解析过程 把var声明的变量提升到当前作用域最前面...把函数声明提升到当前作用域的最前面。 如果函数同名 , 后者会覆盖前者 。 如果var声明的和函数声明的同名, 函数优先。

11.1K40

扫码

添加站长 进交流群

领取专属 10元无门槛券

手把手带您无忧上云

扫码加入开发者社群

相关资讯

热门标签

活动推荐

    运营活动

    活动名称
    广告关闭
    领券