首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

死磕JSvar、let、const 该怎么选?

众所周知,在 Javascript 中就有 3 个关键字可以声明变量,分别是 var,let,const,具体在使用时候我们,怎么选择呢?...var 在 ECMAScript 所有版本中都可以使用,而 const 和 let 只能在 ECMAScript6 及更晚版本中使用。 那么这 3 个关键字 都有哪些异同点及注意事项吗?...window 对象属性, let 和 const 不会; 3、定义在 window 全局变量,不推荐使用 var 声明 或 省略关键字直接定义,推荐使用 window.message = 'hi'...以下代码是没有问题 const message = {}; message.type = 'error' 总结(最佳实践) 不使用 var const 优先,let 次之 在 window...上添加属性,直接使用 window['属性'] = 属性 参考资料:JavaScript高级程序设计(第4版 中文)

1.9K10
您找到你想要的搜索结果了吗?
是的
没有找到

JS中const、var 和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:' + b);//无法输出 2.var定义变量可以修改,如果不初始化会输出undefined,不会报错。...; 6 console.log('函数内var定义a:' + a);//可以输出a=4 7 } 8 change(); 9 console.log('函数调用后var定义a为函数内部修改:' + a...);//可以输出a=4 3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。

2.7K60

JSvar与let、const区别

var与let、const 一、var声明变量会挂载在window上,而let和const声明变量不会: var a = 100; console.log(a,window.a); // 100...声明变量存在变量提升,let和const不存在变量提升 console.log(a); // undefined ===> a已声明还没赋值,默认得到undefined var a = 100; console.log...五、暂存死区 var a = 100; if(1){ a = 10; //在当前块作用域中存在a使用let/const声明情况下,给a赋值10时,只会在当前作用域找变量a, // 而这时...,还未到声明时候,所以控制台Error:a is not defined let a = 1; } 六、const /* *   1、一旦声明必须赋值,不能使用null占位。...* *   2、声明后不能再修改 * *   3、如果声明是复合类型数据,可以修改其属性 * * */ const a = 100; const list = []; list[0] = 10;

2.3K20

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定义变量可以修改...,如果不初始化会输出undefined,不会报错 var a = 1; // var a;//不会报错 console.log('函数外var定义a:' + a);//可以输出a...=1 function change(){ a = 4; console.log('函数内var定义a:' + a);//可以输出a=4 } change...(); console.log('函数调用后var定义a为函数内部修改:' + a);//可以输出a=4 3.let是块级作用域,函数内部使用let定义后,对函数外部无影响。

3.2K30

Golang 语言验证库 Validator 怎么使用

01 介绍 Validator 是基于 tag(标记)实现结构体和单个字段验证库,它包含以下功能: 使用验证 tag(标记)或自定义验证器进行跨字段和跨结构体验证。...别名验证标记,它允许将多个验证映射到单个标记,以便更轻松地定义结构体上验证。 提取自定义字段名称,例如,可以指定在验证时提取 JSON 名称,并在生成 FieldError 中使用该名称。.../go-playground/validator/v10" 02 变量验证 Var 方法使用 tag(标记)验证方式验证单个变量。...,错误输出信息并不友好,错误输出信息中字段不仅没有使用备用名(首字母小写字段名),也没有翻译为中文。...必需 unique 唯一 isDefault 默认 len 长度 email 邮箱格式 05 总结 本文简单介绍了在 Go 语言中比较流行验证库 Validator,通过简单示例介绍了 validator

3.1K40

CSS自定义属性:引入 | 使用var() | cal()计算 | css 与 js 连接

本篇要点: 自定义属性概念 var() calc() 引入 自定义属性,是一种开发者可以自主命名和使用CSS属性。...浏览器在处理像 color 、position 这样属性时,需要接收特定属性,而自定义属性,在开发者赋予它属性之前,它是没有意义。所以要怎么给 CSS 自定义属性赋值呢?...var()可以接收第二个参数作为缺省: .button { background-color: var(--theme-color,gray); } 或者把另一个自定义属性作为缺省: .button...但当你希望不同模块使用不同 --theme-color 怎么办呢?...就和平时用 JS 操作元素任意属性一般,自定义属性也可以通过 getPropertyValue 和 setProperty 方法操作 : const styles = getComputedStle(

41120

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

从以下几个方面解释: 作用域:var是函数作用域,而let是块作用域,也就是说,在函数内声明了var,整个函数内都是有效,比如说在for循环内定义了一个var变量,实际上其在for循环以外也是可以访问...也就是说,let必须是先定义,再使用,而var使用后声明也行,只不过直接使用但是没有却没有定义时候,其为undefined,实际上var有一个变量提升过程。...也就是说,当这个函数作用域被创建时候,实际上var定义变量都会被创建,并且如果此时没有初始化的话,则默认会初始化一个undefined, 补充: var js=function(){} 这种叫做函数表达式...必须先定义后使用 function js(){}这种是函数声明 可以先使用后定义 它会对函数声明进行一个提升,提升只是相当于提前声明,函数提前声明,在使用时候不会报错。...let不能被重新定义,但是var是可以。比如说,你在前面声明了一个变量,后来写代码,因为忘了之前代码逻辑,又声明了一个同名变量,如果这俩变量逻辑不一样,并且后面都要用的话,很容易出问题。

1.4K50

JS|函数返回

我们先来看一组代码 function kunkun(aru){ console.log(aru)}kunkun('打篮球') 这个看似能输出结果,实则是在逻辑上是不合理,我们函数是做某件事或者实现某种功能...所以,接下来我会介绍一种逻辑更严谨代码。 解决方案 return语句 有的时候,我们希望函数将返回返回给调用者,此时通过使用return语句就可以实现。...函数返回格式 function 函数名(){ return 需要返回结果;}函数名(); 函数只是实现某种功能,最终结果需要返回给函数调用者。是通过return来实现。...只要函数遇到return就会把后面的结果,返回给函数调用者。...num2){ return num1 + num2;}console.log(sum(1,2)) 结果输出为:3 由此可知,不要在函数内部输出结果,应该return给函数调用者。

11.4K10

前端面试题:JSlet和var区别

最近很多前端朋友去面试被问到let和var区别,其实阮一峰老师ES6中已经很详细介绍了let用法和var区别。我简单总结一下,以便各位以后面试中使用。...,默认undefined var a = 10; console.log(a); // a => 10 } // 输出结果: undefined 10 99 如果以上题目有理解困难童鞋...ES6可以用let定义块级作用域变量 在ES6之前,我们都是用var来声明变量,而且JS只有函数作用域和全局作用域,没有块级作用域,所以{}限定不了var声明变量访问范围。...机制等 如果把 var改成 let声明: // i虽然在全局作用域声明,但是在for循环体局部作用域中使用时候,变量会被固定,不受外界干扰。...让js真正拥有了块级作用域,也是向这更安全更规范路走,虽然加了很多约束,但是都是为了让我们更安全使用和写代码。

1.4K100

JS数组&两交换不使用第三变量

本文链接:https://ligang.blog.csdn.net/article/details/42048671 数组对象作用是:使用单独变量名来存储一系列!...,并返回删除元素;如果数组为空则返回undefined 4. push:将参数添加到原数组末尾,并返回数组长度 5. arrayObject.concat(arrayX,arrayX,.........不使用第三变量交换: 方法一: var a=2,b=3; a=[b, b=a][0]; //地址指向,必须为对象 方法二: var a=2,b=3; a=b-a; b=b-a; a=b+a...("|"); //a:[1,2,3,4,5] b:"1|2|3|4|5" 13. js排序 sort(orderfunction):按指定参数对数组进行排序 var a = [1,2,3,4,5]...Object这个特性可以用来高效检索Unique字符串集合,遍历Array时间复杂度是O(n),而Object时间复杂度是O(1)。显然,使用Object效率更高!

2.1K31
领券