ES6(ECMAScript2015) 基础知识 浅析
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) 基础知识 浅析的更多相关文章
- Ajax基础知识 浅析(含php基础语法知识)
1.php基础语法 后缀名为.php的文件 (1) echo 向页面中输入字符串 <?php 所有php相关代码都要写在<?php ?>这个标签之中 echo &q ...
- Nodejs 基础知识 浅析
1. 模块化 ①常用模块化规范 CommonJS + nodejs AMD(Asynchronous Module Definition) + RequireJS CMD(Common Module ...
- es2015(es6)基础知识整理(更新中...)
1.let let可以声明块级作用域变量 'use strict'; if (true) { let app = 'apple'; } console.log(app); //外面是访问不到app的 ...
- ES6的基础知识总结
一. ES6 ES6中定义变量使用 let/const let 使用let定义的变量不能进行"变量提升" 同一个作用域中,let不能重复定义相同的变量名 使用var在全局作用域中定 ...
- ES6的基础知识(一)
1.ECMAScript 6.0(以下简称ES6). 2.ECMAScript 和 JavaScript 的关系是,前者是后者的规格,后者是前者的其中一种实现. 3.对ES6支持的浏览器:超过 90% ...
- es6 generator 基础知识
1.定义和使用 function *gen() { return 'first generator'; } // 有点类似类的实例化过程 let generatorResult = gen() // ...
- Echarts 基础知识浅析
1. 引入Echarts Echarts是基于canvas的数据可视化产品,由百度公司推出 参考官方文档,引入教程示例即可,注意有两种引入方式: (1)直接引入 (2)模块化引入 2. 基本API使用 ...
- Angular1 基础知识 浅析(含锚点)
1.angular:前端js框架 https://angularjs.org ① SPA单页应用程序 通过ajax从后台获取数据,动态渲染页面,不出现白屏,提高效率,节省流量 (1)锚点值 锚点:是 ...
- canvas2D 基础知识 浅析
1.canvas HTML5给出的一个可以展示绘图内容的标签 使用领域: (推荐网站:threejs.org) 1. 游戏 2. 可视化数据 3. Banner广告 4. 多媒体 (1)在 c ...
随机推荐
- springmvc 配置多视图(jsp,freemarker,HTML等)
SpringMVC 的 Controller 可以返回各种各样的视图.比如 JSP, JSON, Velocity, FreeMarker, XML, PDF, Excel, 还有Html字符流 等等 ...
- P2419 [USACO08JAN]牛大赛Cow Contest
P2419 [USACO08JAN]牛大赛Cow Contest 题目背景 [Usaco2008 Jan] 题目描述 N (1 ≤ N ≤ 100) cows, conveniently number ...
- Ganglia3.1.7安装与配置(收录)
一.所需要软件 二.安装过程 1.Ganglia运行平台的安装 2.Ganglia依赖库的安装 3.RRDTool的安装 4.Ganglia的安装 (包括使用yum方式 ...
- web开发微信文章目录
Web开发微信文章目录 2015-12-13 Web开发 本文是Web开发微信的文章目录.通过目录查看文章编号,回复文章编号就能查看文章全文. 回复编号查看全文,搜索分类名可以获得该分类下的文章. ...
- SVN 使用时的小错误
在使用SVN的时候总是出现一些小问题,今天又出现了一个,诶,分享一下吧! Error:(个人文件夹名http://www.qdjhu.com/anli_xq/f_wancheng.php) is ...
- 关于相对布局RelativeLayout的各种属性介绍
RelativeLayout相对布局是个人觉得在android布局中比较常用且好用的一个,当然如果想让布局更漂亮是需要多种布局混合搭建的,这里就需要更深入的学习了,在这只介绍下有关相对布局的东西. 相 ...
- ES5新增数组方法(3):some
检查数组元素中是否有元素符合指定. // 数组中的元素部分满足指定条件返回true let arr = [1, 3, 5, 7, 9]; console.log(arr.some((value, in ...
- 12.0 Excel表格读取
Pycharm安装 xlrd 首先在xuexi目录下创建一个ExcelFile文件,让后在ExcelFile下创建一个Excel表格 创建表格时记得把单元格的格式设置为[文本] 我们设置为文本之后,存 ...
- 标准H5文件头的写法
整理代码如下: <!DOCTYPE html> <!-- 声明文档语言属性 --> <!-- 中文 --> <html lang="zh-Hans& ...
- Python全栈 MongoDB 数据库(聚合、二进制、GridFS、pymongo模块)
断网了2天 今天补上 聚合操作: 对文档的信息进行整理统计的操作 返回:统计后的文档集合 db.collection.aggregate() 功能:聚合函数,完成聚合操作 参数:聚合条件,配 ...