ES6基础知识介绍

目录
  • 一、ECMAScript和JavaScript关系
  • 二、let命令
  • 三、const命令
  • 四、变量的解构赋值
    • 1、数组的解构赋值
    • 2、对象的解构赋值

一、ECMAScript和JavaScript关系

JavaScript 的创造者 Netscape 公司,决定将 JavaScript 提交给标准化组织 ECMA,希望这种语言能够成为国际标准,但是JavaScript本身也已经被 Netscape 公司注册为商标,后面的标准都由ECMA制定,取名ECMAScript。

那么ES6这个版本引入的新内容较多,通常指JavaScript语言的下一个版本。

二、let命令

ES6 新增了let命令,用来声明变量。它的用法类似于var,但是所声明的变量,只在let命令所在的代码块内有效。

var和let定义变量区别:

<script>
	//var的作用域是函数级的(函数内部定义变量只能函数里面使用)
	// function showName()
	// {
	// 	var myName = "张学友";
	// 	alert(myName + "欢迎您!");  //此处的myName为"张学友"
	// }
	// showName();
	// alert(myName + "欢迎您!");  //此处会报错,myName只能在showName函数中使用

	//var的作用域是函数级的(在代码块中定义的变量可以在代码块之外使用)
	// if(1==1)
	// {
	// 	var myName = "张学友";
	// }
	// alert(myName + "欢迎您!"); //此处可以运行

	//let的作用域是代码块级别的
	// if(1==1)
	// {
	// 	let myName = "张学友";
	// }
	// alert(myName + "欢迎您!"); //此处会报错

	//let不存在变量提升
	// console.log(a);  //报错
	// let a = "apple";

	// console.log(b);  //undefined
	// var b = "banana";
</script>

var和let在循环计数时候的区别:

<script>
	// for(var i = 1;i <= 10;i++)
	// {
	// 	//
	// }
	// alert(i);  //此处会打印11,i在循环体内和循环体外都可以使用
	//此时计数器的变量泄露成了全局变量

	// for(let i = 1;i <= 10;i++)
	// {
	// 	//
	// }
	// alert(i);  //此处会报错,i只在循环体内有效,在循环体外无效	

	// 输出十个11
	// i是全局的,定时器代码在循环之后发生,所以打印十个11
	// for (var i = 1; i <= 10; i++) {
	//   setTimeout(function(){
	// 	console.log(i);
	//   })
	// }

	//输出1 2 3 4 5 6 7 8 9 10
	for (let j = 1; j <= 10; j++) {
	  setTimeout(function(){
		console.log(j);
	  })
	}
</script>

循环绑定网页元素事件中var和let的区别:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title>循环绑定按钮事件</title>
	</head>
	<body>
		<h2>点击三个按钮分别弹出1,2,3</h2>
		<input type="button" class="myButton" value="第一个按钮" />
		<input type="button" class="myButton" value="第二个按钮"/>
		<input type="button" class="myButton" value="第三个按钮"/>
	</body>
</html>
<script>
	//在此案例中i是全局的,点击按钮发生在循环之后,所以打印结果全部为4
	// var list = document.getElementsByClassName("myButton");
	// for(var i = 0;i < list.length;i++)
	// {
	// 	list[i].onclick = function(){
	// 		alert(i+1);
	// 	}
	// }

	//上述代码不能打印1,2,3,而是打印4,需要采取JS闭包来解决此问题;
	//闭包就是能够读取其他函数内部变量的函数
	// var list = document.getElementsByClassName("myButton");
	// for(var i = 0;i < list.length;i++)
	// {
	// 	list[i].onclick = (function(num)
	// 	{
	// 		return function(){
	// 			alert(num);
	// 		}
	// 	})(i+1);
	// }

	//如果使用ES6中let关键字则不存在上面演示的问题
	var list = document.getElementsByClassName("myButton");
	for(let i = 0;i < list.length;i++)
	{
		list[i].onclick = function(){
			alert(i+1);
		}
	}
</script>

三、const命令

const声明一个只读的常量。一旦声明,常量的值就不能改变。

<script>
	// const PI = 3.14;
	// PI = 3.15; //此处会报错,const声明的变量不能改变其值

	//const一旦声明变量,就必须立即初始化,不能留到以后赋值。
	//const PI; //报错

	//const实际上保证的,并不是变量的值不得改动,
	//而是变量指向的那个内存地址所保存的数据不得改动。
	const arr = [];
	arr.push('jack'); //可以执行
	arr.push("rose"); //可执行
	console.log(arr[0]);
	console.log(arr[1]);

</script>

四、变量的解构赋值

1、数组的解构赋值

ES6 允许按照一定模式,从数组和对象中提取值,对变量进行赋值

// let a = 1;
// let b = 2;
// let c = 3;
//上述代码可以如下编写(从数组中提取值,按照对应位置,对变量赋值)
// let[a,b,c]=[1,2,3];

数组解构赋值案例:

//let [a, [[b], c]] = [1, [[2], 3]]; //a=1,b=2,c=3
//let [ , , c] = ["jack", "rose", "mike"];  //c=mike
//let [x, , y] = [1, 2, 3];  //x=1,y=3
//let [head, ...tail] = [1, 2, 3, 4]; //head=1,tail=[2,3,4]
//let [x, y, ...z] = ['a']; //x=a,y=undefined,z=[]

解构不成功,变量的值就等于undefined:

//let [foo] = []; //解构不成功,foo=undefined
//let [bar, foo] = [1]; //bar=1,foo解构不成功foo=undefined

不完全解构:

左边的模式只能匹配右边的一部分,也可以解构成功:

let [x, y] = [1, 2, 3]; //x=1,y=2

字符串解构(将字符串当成一个数组):

let [a, b, c, d, e] = 'hello';
console.log(a);
console.log(b);
console.log(c);
console.log(d);
console.log(e);

默认值:

解构赋值允许指定默认值

//let [foo = true] = []; //foo=true;
//let [x, y = 'b'] = ['a']; // x='a', y='b'
//let [x, y = 'b'] = ['a', undefined]; // x='a', y='b'
//let [x = 1] = [null];  //x=null(只有当一个数组等于undefined,默认值才会生效)

默认值可以引用解构赋值的其他变量,但该变量必须已经声明

//let [x = 1, y = x] = [];     // x=1; y=1
//let [x = 1, y = x] = [2];    // x=2; y=2
//let [x = 1, y = x] = [1, 2]; // x=1; y=2
//let [x = y, y = 1] = [];     // ReferenceError: y is not defined

2、对象的解构赋值

解构不仅可以用于数组,还可以用于对象。

let { foo, bar } = { foo: 'aaa', bar: 'bbb' }; //foo='aaa', bar='bbb'

以上代码看上去和数组解构赋值没有多大区别,但是:

(1) 数组解构中数组的元素是按次序排列的,变量的取值由它的位置决定;

(2) 对象解构中对象的属性没有次序,变量必须与属性同名,才能取到正确的值 ;

如下:

let { bar, foo } = { foo: 'aaa', bar: 'bbb' };   //foo="aaa"  bar= "bbb"
let { baz } = { foo: 'aaa', bar: 'bbb' };  //baz = undefined,解构失败,值为undefined

对象的解构赋值,可以很方便地将现有对象的方法,赋值到某个变量:

// 例一
let { log, sin, cos } = Math; //将Math对象的对数、正弦、余弦三个方法,赋值到对应的变量上
// 例二
const { log } = console; //将console.log赋值到log变量,简化代码
log('hello') // hello

如果变量名与属性名不一致,必须写成下面这样:

let { foo: baz } = { foo: 'aaa', bar: 'bbb' };	//baz = "aaa"

let obj = { first: 'hello', last: 'world' };
let { first: f, last: l } = obj;   //f = 'hello'	l = 'world'

这实际上说明,对象的解构赋值是下面形式的简写

let { foo: foo, bar: bar } = { foo: 'aaa', bar: 'bbb' };

真正被赋值的是后者,而不是前者:

let { foo: baz } = { foo: 'aaa', bar: 'bbb' };
//baz = "aaa"	foo = error: foo is not defined

与数组一样,解构也可以用于嵌套结构的对象 :

let obj = {
  p: [
    'Hello',
    { y: 'World' }
  ]
};

let { p: [x, { y }] } = obj;
x // "Hello"
y // "World"

注意,这时p是模式,不是变量,因此不会被赋值。如果p也要作为变量赋值,可以写成下面这样。

let obj = {
  p: [
    'Hello',
    { y: 'World' }
  ]
};

let { p, p: [x, { y }] } = obj;

x // "Hello"
y // "World"
p // ["Hello", {y: "World"}]

默认值:

let {x = 3} = {};
x // 3

let {x, y = 5} = {x: 1};
x // 1
y // 5

let {x: y = 3} = {};
y // 3

let {x: y = 3} = {x: 5};
y // 5

let { message: msg = 'Something went wrong' } = {};
msg // "Something went wrong"

默认值生效的条件是,对象的属性值严格等于undefined

var {x = 3} = {x: undefined};
x // 3

var {x = 3} = {x: null};
x // null

注意点:

如果要将一个已经声明的变量用于解构赋值,必须非常小心

// 错误的写法
let x;
{x} = {x: 1};

上面代码的写法会报错,因为 JavaScript 引擎会将{x}理解成一个代码块, 只有不将大括号写在行首,才能解决

这个问题。

// 正确的写法
let x;
({x} = {x: 1});

由于数组本质是特殊的对象,因此可以对数组进行对象属性的解构。

let arr = [1, 2, 3];
let {0 : first, [arr.length - 1] : last} = arr;  //利用数组下标解构赋值
first // 1
last // 3

到此这篇关于ES6基础知识的文章就介绍到这了。希望对大家的学习有所帮助,也希望大家多多支持我们。

(0)

相关推荐

  • es6基础学习之解构赋值

    前言 es6的语法已经出了很长的时间了,在使用上也可以通过babel这类的编译工具转译为浏览器可以识别的es5的语法,但是依旧有很多开发在写代码的时候,依旧没有用es6的语法,而是习惯使用老的语法,这篇文章主要会介绍解构赋值基本用法以及在实际使用场景中相比es5语法的优势,让大家从根本上了解es6语法的优势 下面话不多说了,来一起看看详细的介绍吧 基本用法 数组解构 让我们一起先来看数组解构的基本用法: let [a, b, c] = [1, 2, 3] // a=1, b=2, c=3 let

  • ES6基础之解构赋值(destructuring assignment)

    我们经常可以在其他编程语言(如GO语言)中看到多返回值这种特性,因为在很多实际场景中,函数的返回值中,函数的返回值并不只有一个单一的值.ES6之前,并没有可以直接使用语法来实现多返回值的特性.ES6终于出现了解构赋值的语法糖来解决此类问题. 解构赋值是一种表达式,允许您使用数组或对象,将可迭代对象的值或属性分配给变量.解构赋值能让我们用更简短的语法进行多个变量的赋值,大大的减少了代码量.解构表达式有两种:array和object. 今天的文章笔者将从以下方面进行介绍: 使用数组表达式解构赋值 常

  • ES6基础之默认参数值

    如果调用函数的过程中,定义的参数缺失,此参数变量的值则会是undefined.怎么给缺失的参数赋值默认值,在ES6之前,没有简洁的语法设置缺失参数的默认值,但是我们一般可以这么编写代码解决缺失参数默认值: function myFunction(x, y, z) { x = x === undefined ? 1 : x; y = y === undefined ? 2 : y; z = z === undefined ? 3 : z; console.log(x, y, z); //Outpu

  • ES6基础之展开语法(Spread syntax)

    展开语法用"..."进行表示,展开语法将可迭代的对象拆分成独立的值(语法层面展开).扩展语法通常用于将可迭代的对象的值传递到函数的参数中.今天小编将从以下方面进行介绍: 函数传参中的应用 数组的相关应用 剩余参数的应用 函数传参中的应用 ES6之前,如果我们希望将数组作为参数分别传递给函数中的参数,我们可以使用Function的apply()方法.如下段代码所示: function myFunction(a, b) { return a + b; } var data = [1, 4]

  • Node中使用ES6语法的基础教程

    相关背景介绍 我们现在大多数人用的语法javascript 其实版本是ecmscript5,也是就es5.这个版本己经很多年了,且完美被各大浏览器所支持.所以很多学js的朋友可以一直分不清楚es5和javscript的关系.javascript是一门编程语言,那么它就会有版本,es5还是es6 就就是它的版本号.最新版es7己经在紧锣密布的进行中,它最新的语法会让我们写代码更新的行云流水. 引言 Node本身已经支持部分ES6语法,但是import export,以及async await(No

  • ES6基础之数组和对象的拓展实例详解

    本文实例讲述了ES6基础之数组和对象的拓展.分享给大家供大家参考,具体如下: 数组的扩展 1.拓展运算符('...'),它相当于rest参数的逆运算,用于将一个数组转换为用逗号分隔的参数序列: console.log(...[1, 2, 3]) // 1 2 3 console.log(1, ...[2, 3, 4], 5) // 1 2 3 4 5 2.如果扩展运算符后面是一个空数组,则不产生任何效果: [...[], 1] // [1] 3.常见的拓展运算符的应用: //合并数组 let a

  • JavaScript ES6常用基础知识总结

    ES6 let与const及其相关 块级作用域 ES6新增了块级作用域,总结一句话大致就是:大括号{}包起来的代码块基本山都可以当做块级作用域. 常见的有 直接使用{}包起来: { var a = 4 } 函数体大括号,if-else大括号,for循环大括号,switch大括号,try-catch大括号等. 需要注意的是,for循环,每一次循环时的{}都是一个独立的块级作用域. for(let i=0; a < 5; i++){ let j = i } 上面代码循环了五次,实际上有五个独立的j.

  • ES6基础之字符串和函数的拓展详解

    本文实例讲述了ES6基础之字符串和函数的拓展.分享给大家供大家参考,具体如下: 字符串的拓展 1.ES6为字符串添加了遍历器接口,因此可以使用for...of循环遍历字符串 2.字符串新增的 includes().startsWith().endsWidth() 三个方法用于判断某一字符串是否包含于另一字符串 includes():返回布尔值,表示源字符串中是否包含参数字符串. startsWith():返回布尔值,表示参数字符串是否在源字符串的头部. endsWith():返回布尔值,表示参数

  • ES6基础之 Promise 对象用法实例详解

    本文实例讲述了ES6基础之 Promise 对象用法.分享给大家供大家参考,具体如下: Promise 对象 1.Promise对象是ES6对异步编程的一种解决方案,它有以下两个特点: Promise对象代表一个异步操作,它只有三种状态:Pending(进行中).Resolved(已完成,又称 Fulfilled)和Rejected(已失败),并且该状态不会受外界的影响 Promise对象的状态改变,只有两种可能:从 Pending 变为 Resolved 或者从 Pending 变为 Reje

  • ES6基础知识介绍

    目录 一.ECMAScript和JavaScript关系 二.let命令 三.const命令 四.变量的解构赋值 1.数组的解构赋值 2.对象的解构赋值 一.ECMAScript和JavaScript关系 JavaScript 的创造者 Netscape 公司,决定将 JavaScript 提交给标准化组织 ECMA,希望这种语言能够成为国际标准,但是JavaScript本身也已经被 Netscape 公司注册为商标,后面的标准都由ECMA制定,取名ECMAScript. 那么ES6这个版本引入

  • java网络编程基础知识介绍

    网络基础知识 1.OSI分层模型和TCP/IP分层模型的对应关系 这里对于7层模型不展开来讲,只选择跟这次系列主题相关的知识点介绍. 2.七层模型与协议的对应关系 网络层 ------------ IP(网络之间的互联协议) 传输层 ------------ TCP(传输控制协议).UDP(用户数据报协议) 应用层 ------------ Telnet(Internet远程登录服务的标准协议和主要方式).FTP(文本传输协议).HTTP(超文本传送协议) 3.IP地址和端口号 1.ip地址用于

  • C# 最基础知识介绍--多态

    目录 一.C# 多态性 二.静态多态性 三.函数重载 四.C# 运算符重载 1.运算符重载的实现 2.可重载和不可重载运算符 五.动态多态性 前言:

  • ASP.NET母版页基础知识介绍

    模板页是做什么的? 利用模板页可以方便快捷的创建统一风格的ASP.NET网站,并且容易管理和维护,提高了效率. 模板页为网页定义所需要的外观和标准,在母版的基础上创建包含显示内容的各个内容页.当用户请求内容页时,这些内容页与母版页合并,这样,模板页的布局与内容页的布局就可以组合在一起输出了. 模板页一般用来: 1.通过修改模板页来处理网页的通用功能. 2.可以方便的创建一组控件和代码,并应用于一组网页. 3.通过允许控制占位符控件的呈现方式,模板页可以在细节上控制最终页的布局. 模板页与普通页

  • PowerShell中的变量基础知识介绍

    本文介绍在PowerShell中,如何使用变量.变量可以存储程序中的数量,比如开发者的赋值.命令的执行结果等. 变量拿来干嘛的,不用我多说了,写过程序的兄弟们都知道:如果程序中没有变量,那真的就不能让程序了!连批处理里面都有变量了,那PowerShell中自然就更不能没有. 1.PowerShell中的变量都是对象 PowerShell中的变量是基于.NET Framework的,所以PowerShell中的变量跟.NET中的变量一样:都是对象,通通都是对象! 复制代码 代码如下: $i=1 $

  • ORACLE 12C PDB 维护基础知识介绍

    先说基本用法: 先按11G之前进行 conn / as sysdba; create user test identifed by test; ORA-65096: 公用用户名或角色名无效. 查官方文档得知"试图创建一个通用用户,必需要用C##或者c##开头",这时候心里会有疑问,什么是common user?不管先建成功了再说 create C##user test identifed by test; 创建成功 SQL>show con_name; CON_NAME ----

  • PHP基础知识介绍

    php中的整形数是有符号的,不能表示无符号整数,当整形数超出范围时,会自动从整形数转化成float数,可以用php_int_size常量来查看php整数类型所占字节,一般为4个字节,所以可以估算出整形数的范围,最高位数符号位.也可以用php_int_max常量来查看int的最大值. 小知识点: 1.   当变量为0.0或"0"在布尔变量中均表示false: 2.   字符串变量用双引号时其中变量和转义字符可以按照其定义正常输出,而用单引号输出内容时它会原样输出其内容,即转义字符或变量不

  • 正则表达式模式匹配字符串基础知识

     介绍 在实际项目中有个功能的实现需要解析一些特定模式的字符串.而在已有的代码库中,在已实现的部分功能中,都是使用检测特定的字符,使用这种方法的缺点是: 逻辑上很容易出错 很容易漏掉对一些边界条件的检查 代码复杂难以理解.维护 性能差 看到代码库中有一个cpp,整个cpp两千多行代码,有个方法里,光解析字符串的就有400余行!一个个字符对比过去,真是不堪入目.而且上面很多注释都已经过期,很多代码的书写风格也各不相同,基本可以判断是过了很多人手的. 在这种情况下,基本没办法还沿着这条老路走下去,自

  • Lua教程(二):基础知识、类型与值介绍

    一.基础知识: 1. 第一个程序和函数:     在目前这个学习阶段,运行Lua程序最好的方式就是通过Lua自带的解释器程序,如:   复制代码 代码如下: /> lua     > print("Hello World")     Hello World 这样我们就可以以交互性的方式输入lua代码,并立即得到执行结果了.对于代码块较少的测试程序来说,这种方式确实是非常方便的,然而对于相对复杂的程序而言,这种方式就不是很合适了.如果是这样,我们可以将Lua代码保存到一个独立

  • PHP内核介绍及扩展开发指南—基础知识

    一. 基础知识 本章简要介绍一些Zend引擎的内部机制,这些知识和Extensions密切相关,同时也可以帮助我们写出更加高效的PHP代码. 1.1 PHP变量的存储 1.1.1 zval结构 Zend使用zval结构来存储PHP变量的值,该结构如下所示: 复制代码 代码如下: typedef union _zvalue_value { long lval; /* long value */ double dval; /* double value */ struct { char *val;

随机推荐