1.块级作用域(let

{

let fruit = “apple”;

}

console.log(fruit)

会报错,因为{ }大括号包含的区域为块级作用域,let在其中申明的变量只能在该块中生效

2.恒量声明(const

const fruit = "apple";

fruit = "banana";

console.log(fruit)

会报错,因为const声明的是恒量,不能被重新赋值,只能用方法改变,如const arr = [ ],可以使用arr.push()

3.结构写法

数组写法:

function breakfast() {

return ["cake", "tea", "apple"];

}

let [dessert, drink, fruit] = breakfast();

console.log(dessert, drink, fruit) ------ cake tea apple

对象写法:

function breakfast() {

return { dessert: "cake" , drink: "tea" , fruit: "apple"};

}

let {dessert: drink , drink: dessert , fruit: fruit} = breakfast();

console.log(dessert, drink, fruit) ------ tea cake apple

4.用法

当做展开的用法:

let fruits = ['apple', 'banana'],

foods = ['cake', ...fruits];

console.log(fruits) ------ ["apple", "banana"]

console.log(...fruits) ------ apple banana

console.log(foods) ------- ["cake", "apple", "banana"]

函数参数数组包容:

function breakfast(dessert, drink, ...foods) {

console.log(dessert, drink, foods) ------ cake tea ["apple", "pear"]

}

breakfast("cake", "tea", "apple", "pear")

5.字符模板

 let dessert="cake",drink="tea";

let breakfast=`今天早餐是${dessert}${drink}!`使用反引号包裹

console.log(breakfast) ------ 今天早餐是cake和tea!

查看字符串以什么开头:

console.log(breakfast.startsWith(‘今天’)) ------ true

查看字符串以什么结尾:

console.log(breakfast.endsWith(‘今天’)) ------ false

查看字符串以是否包含什么:

console.log(breakfast.includes(‘今天’)) ------ true

标签字符串:kitchen是设置的任意标签名

var dessert = "cake",drink = "tea";

var breakfast = kitchen `今天早餐是${dessert}和${drink}!`;

function kitchen(string, ...values) {

console.log(string); ------ ["今天早餐是", "和", "!", raw: Array[3]]

console.log(values); ------ ["cake", "tea"]

}

6.函数设置

设置函数参数的默认值:

function breakfast(drink = "tea", fruit = "apple") {

return `${drink} ${fruit}`;

}

console.log(breakfast()) ------ tea apple

console.log(breakfast("coffee", "banana")) ------ coffee banana

结构对象:

function breakfast(dessert, drink, {location,name}={}) { 设置默认值防止报错

console.log(dessert, drink, location,name) ------ cake tea 兰州 董小姐

}

breakfast("cake", "tea", {location:"兰州",name:"董小姐"})

name属性:

let func=function breakfast() { }

console.log(func.name) ------ breakfast

Arrow Functions 箭头函数:

let breakfast = (dessert, drink) => {

console.log(dessert + drink) ------ caketea

return dessert

}

console.log(breakfast('cake', 'tea')) ------ cake

let lunch = (dessert, drink) => dessert

console.log(lunch('cake', 'tea')) ------- cake

创建对象属性中的函数

let dessert = 'cake' , drink = 'tea';

let food = {

dessert,

drink,

 breakfast() { }  类似于breakfast: function() { }

}

console.log(food) ------ Object {breakfast: () , dessert: "cake" , drink: "tea"}

console.log(food.breakfast) ------ breakfast() {}

迭代next()

function* chef(foods) {  function后面加上*

for (var i = 0; i < foods.length; i++) {

yield foods[i];

}

}

let dinner = chef(["egg" , "apple"])

console.log(dinner.next()) ------ Object {value: "egg", done: false}

console.log(dinner.next()) ------ Object {value: "apple", done: false}

console.log(dinner.next()) ------ Object {value: undefined, done: true}

7.对象设置

设置具有空格的属性名:

let food={};

// food.hot drink="tea";   直接设置会报错

food['hot drink']="tea";

console.log(food) ------ Object {hot drink: "tea"}

判断相等:

console.log(+0 === -0) ------ true

console.log(Object.is(+0, -0)) ------ false

console.log(NaN === NaN) ------ false

console.log(Object.is(NaN, NaN)) ------ true

属性赋值:

let breakfast = {}

Object.assign(

breakfast,

{drink: 'beer'},

{fruit: 'apple'},

{fruit: 'pear'}  此处会替换上面设置的apple

)

console.log(breakfast) ------ Object {drink: "beer", fruit: "pear"}

判断设置对象的prototype

let breakfast = {

getDrink() { return "beer" }

}

let lunch = {

getDrink() { return "tea" }

}

let sunday = Object.create(breakfast);

console.log(sunday.getDrink()); ------ beer

console.log(Object.getPrototypeOf(sunday) === breakfast) ------ true

Object.setPrototypeOf(Sunday , lunch);

console.log(sunday.getDrink()); ------ tea

console.log(Object.getPrototypeOf(sunday) === lunch) ------ true

设置对象的__proro__

let breakfast = {

getDrink() { return "beer" }

}

let lunch = {

getDrink() { return "tea" }

}

let sunday = { __proto__:breakfast }

console.log(sunday.getDrink()); ------ beer

console.log(Object.getPrototypeOf(sunday) === breakfast) ------ true

sunday.__proto__=lunch;

console.log(sunday.getDrink()); ------ tea

console.log(Object.getPrototypeOf(sunday) === lunch) ------ true

sunday = {

__proto__: breakfast,

getDrink() {

return super.getDrink() + "tea";  super可以执行之前设置的方法

}

}

console.log(sunday.getDrink()); ------ beertea

8.class

创建一个类:

class chef {

constructor(food) {

this.food = food;

this.dish = [];

}

set menu(dish) {

this.dish.push(dish);

}

get menu() {

return this.dish

}

cook() {

console.log(this.food); ------ apple

}

static cook2(food) {  设置静态的方法

console.log(food) ; ------ orange

}

}

let dinner = new chef("apple")

dinner.cook();

console.log(dinner.menu = "banana"); ------ banana

console.log(dinner.menu = "pear"); ------ pear

console.log(dinner.menu); ------ [‘banana’ , ‘pear’]

chef.cook2("orange") 调用静态方法

类的继承:

    class Person {

constructor(name, birthday) {

this.name = name;

this.birthday = birthday;

}

intro() {

return `${this.name},${this.birthday}`;

}

}

 class Chef extends Person Chef通过extends继承Person的内容

constructor(name, birthday) {

super(name, birthday);   执行Person中的内容

}

}

let dinner = new Chef('Tom', '1992-03-07');

console.log(dinner.intro()); ------ Tom,1992-03-07

9.创建一个Map

let food = new Map();

let fruit = {} , cook = function() {} , dessert = 'cake';

food.set(fruit, 'apple');

food.set(cook, 'fork');

food.set(dessert, 'cake');

console.log(food); ------ Map {Object {} => "apple", function => "fork", "cake" => "cake"}

console.log(food.size); ------ 3

console.log(food.get(fruit)); ------ apple

food.delete(dessert);

console.log(food.has(dessert)); ------ false

food.forEach((value, key) => {

console.log(`${key}=${value}`);

})

------ [object Object]=apple

------ function () {}=fork

food.clear();

10.模块导入需要使用辅助工具,查阅相关文档

ES6(ECMAScript2015) 基础知识 浅析的更多相关文章

  1. Ajax基础知识 浅析(含php基础语法知识)

    1.php基础语法    后缀名为.php的文件 (1) echo   向页面中输入字符串  <?php    所有php相关代码都要写在<?php ?>这个标签之中 echo &q ...

  2. Nodejs 基础知识 浅析

    1. 模块化 ①常用模块化规范 CommonJS + nodejs AMD(Asynchronous Module Definition) + RequireJS CMD(Common Module ...

  3. es2015(es6)基础知识整理(更新中...)

    1.let let可以声明块级作用域变量 'use strict'; if (true) { let app = 'apple'; } console.log(app); //外面是访问不到app的 ...

  4. ES6的基础知识总结

    一. ES6 ES6中定义变量使用 let/const let 使用let定义的变量不能进行"变量提升" 同一个作用域中,let不能重复定义相同的变量名 使用var在全局作用域中定 ...

  5. ES6的基础知识(一)

    1.ECMAScript 6.0(以下简称ES6). 2.ECMAScript 和 JavaScript 的关系是,前者是后者的规格,后者是前者的其中一种实现. 3.对ES6支持的浏览器:超过 90% ...

  6. es6 generator 基础知识

    1.定义和使用 function *gen() { return 'first generator'; } // 有点类似类的实例化过程 let generatorResult = gen() // ...

  7. Echarts 基础知识浅析

    1. 引入Echarts Echarts是基于canvas的数据可视化产品,由百度公司推出 参考官方文档,引入教程示例即可,注意有两种引入方式: (1)直接引入 (2)模块化引入 2. 基本API使用 ...

  8. Angular1 基础知识 浅析(含锚点)

    1.angular:前端js框架  https://angularjs.org ① SPA单页应用程序 通过ajax从后台获取数据,动态渲染页面,不出现白屏,提高效率,节省流量 (1)锚点值 锚点:是 ...

  9. canvas2D 基础知识 浅析

    1.canvas HTML5给出的一个可以展示绘图内容的标签 使用领域: (推荐网站:threejs.org) 1. 游戏   2. 可视化数据  3. Banner广告  4. 多媒体 (1)在 c ...

随机推荐

  1. python2.7练习小例子(二十六)

        26):题目:给一个不多于5位的正整数,要求:一.求它是几位数,二.逆序打印出各位数字.     程序分析:学会分解出每一位数.     程序源代码: #!/usr/bin/python # ...

  2. ORA-12705: Cannot access NLS data files or invalid

    RedHat7.1 Oracle11gr2 oracle 默认的编码方式如下:SQL> select userenv('language') from dual; USERENV('LANGUA ...

  3. mybatis-generator自定义注释生成

    最近做的项目发现没有中文注释,故查找资料,特此记录. 本文所用的是基于mybatis-generator 1.3.2版本来完成的. mybatis-generator 自动生成的代码注释是很反人类的, ...

  4. 初步学习pg_control文件之七

    接前文 初步学习pg_control文件之六  看   pg_control_version 以PostgreSQL9.1.1为了,其HISTORY文件中有如下的内容: Release Release ...

  5. THUSC 2018 游记

    现在是闭幕式,我坐在西郊宾馆后排,开始写这篇游记. day0 早上从临汾坐火车到北京,12:52左右到了北京. 这次北京的地铁安检没有排成很长的队,但是在买票的时候我惊喜地发现我身上没有零钱--所幸北 ...

  6. Bug是一种财富-------研发同学的错题集、测试同学的遗漏用例集

    此文已由作者王晓明授权网易云社区发布. 欢迎访问网易云社区,了解更多网易技术产品运营经验. 各位看官,可能看到标题的你一定认为这是一篇涉嫌"炒作"的文章,亦或是为了吸引眼球而起的标 ...

  7. 29、phonegap入门

    0. PhoneGap介绍 0.1  什么是PhoneGap? PhoneGap是一个基于HTML.CSS.JS创建跨平台移动应程序的快速开发平台.与传统Web应用不同的是,它使开发者能够利用iPho ...

  8. 【赛后补题】(HDU6223) Infinite Fraction Path {2017-ACM/ICPC Shenyang Onsite}

    场上第二条卡我队的题目. 题意与分析 按照题意能够生成一个有环的n个点图(每个点有个位数的权值).图上路过n个点显然能够生成一个n位数的序列.求一个最大序列. 这条题目显然是搜索,但是我队在场上(我负 ...

  9. iframe底边多出4px或5px解决办法

    问题: 在处理iframe框架自适应时,并且已经去掉iframe的边框,但仍然出现底边多出4px或5px高度的情况.如图 <div id="content"> < ...

  10. Vue折腾记 - (2)写一个不大靠谱的面包屑组件

    先看效果图 我把页面标题和面包屑封装到一起..就不用涉及到组件的通讯了,不然又要去监听路由或者依赖状态去获取 这里写图片描述 疑惑解答: 点击父(也就是折叠菜单)为什么会跑到子菜单第一个 因为我第一个 ...