ES6笔记

作者: Rc在努力 | 来源:发表于2019-04-30 22:48 被阅读0次

es6语法

块级作用域 let

var 声明的变量没有局部作用域
let 声明的变量有局部作用域

'use strict';

if (true) {
    var animal = "cat"
    let fruit = "apple"
}
//animal可以输出,但是fruit不可以输出,因为变量定义为let,是块级作用域
console.log(animal);
console.log(fruit);

恒量 const

'use strict';

const animal = "cat";
console.log(animal);

//错误:这里重复声明了
const animal = 'dong';
console.log(animal);

// const 限制的是赋值的动作
const fruit = [];
fruit.push("apple");
fruit.push("lemon");
//这样是可以的
console.log(fruit);
//这里会报错因为fruit是常量
fruit =[];
console.log(fruit);

解构数组

'use strict';

function animals() {
    return ["cat", "dog", "mouse"]
}

var tmp = animals(), cat = tmp[0], dog = tmp[1], mouse = tmp[2];

console.log(cat, dog, mouse);

//结构数组
let [animal1, animal2, animal3] = animals();
console.log(animal1, animal2, animal3);

解构对象

'use strict';


function login() {
    return {username: 'rc', userpassword: '123456'}
}

//解构对象,前面的是对象的key
let {username: name, userpassword: passowrd} = login();

console.log(name, passowrd);

模版字符串

'use strict';


let day = '星期一';

let str = `今天是${day}`;

console.log(str);

带标签的模板字符串

'use strict';


let username = "rc", password = "123";

let loginInfo = login `用户名是${username} 密码是${password}`;

function login(string, ...values) {
    // ["用户名是", " 密码是", "", raw: Array(3)]
    // 0: "用户名是"
    // 1: " 密码是"
    // 2: ""
    console.log(string);
    //["rc", "123"]
    console.log(values);
}

console.log(loginInfo);

判断字符串里是否包含其他字符串

'use strict';


let username = "rc", password = "123";

let loginInfo = `用户名是${username} 密码是${password}`;


//判断字符串以什么开头 ,这里返回true
console.log(loginInfo.startsWith("用户名"));

//判断字符串以什么结尾 ,这里返回true
console.log(loginInfo.endsWith(password));

//判断字符串包含什么字符,这里返回false
console.log(loginInfo.includes("1234"));

函数默认参数

'use strict';

function login(username = 'rc', password = '123') {
    return `用户名是${username} 密码是${password}`
}

//不传入函数值,就会使用默认的值
console.log(login());

展开操作符

'use strict';

let username = ['张三', '李四'];

//输出 ['张三', '李四']
console.log(username);
// 对象拷贝,使用对象拓展运算符
//输出张三 李四(这里将数组的每一个元素输出)
console.log(...username);

// 输出["王五", "张三", "李四"]
let otheruser =['王五',...username];
console.log(otheruser);

剩余操作符

'use strict';

//...在参数里面代表剩余操作符
function username(firstUser, secondUser, ...otherUser) {
    //console中的otherUser表示将...otherUser放大otherUser数组中
    console.log(firstUser, secondUser, otherUser);
    // console.log(firstUser, secondUser, ...otherUser); 这里表示的就是展开操作符
}

// 输出 aaa bbbb  ["cccc", "ddddd"]
username("aaa", 'bbbb', 'cccc', 'ddddd');

结构参数

'use strict';

function meeting(when, where, {person, activity} = {}) {
    console.log(when, where, person, activity);
}

//输出:12点 广州 rc movie
meeting('12点', '广州', {person: 'rc', activity: 'movie'});

函数的名字--name属性

'use strict';

let login = function () {

};

//输出login
console.log(login.name);


let logout = function MyLogout() {

};

//输出MyLogout
console.log(logout.name);

箭头函数

'use strict';

// let login = (username, password) => username + password;


//如果有其他操作,可以在外面包裹{}
// let login = (username, password) => {
//     return username + password;
// };

// 等价于
// let login = function login(username, password) {
//     return username + password;
// };

//输出rc123
console.log(login('rc', '123'));

对象表达式

'use strict';

let myUserName = 'rc', myPassword = '123';

let login = {
    username: myUserName,
    password: myPassword
};
//输出{username: "rc", password: "123"}
console.log(login);

//如果变量名和属性一样的话可以直接加属性,不用指定值
let myLogin = {
    myUserName,
    myPassword
};
//输出{myUserName: "rc", myPassword: "123"}
console.log(myLogin);


let otherLogin ={
    login:function () {

    }
};

//等价于
// let otherLogin ={
//     login () {
//
//     }
// };

对象属性名

'use strict';

let fruit = {};

fruit.apple ='苹果';

//如果属性名有空格,可以这样[`green apple`]添加属性
fruit[`green apple`] ='青苹果';

let otherApple ='other apple';

//也可以通过定义一个变量来添加属性
fruit[otherApple]='其他苹果';

//输出{apple: "苹果", green apple: "青苹果", other apple: "其他苹果"}
console.log(fruit);


对比两个值是否相等

'use strict';

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

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


//false
console.log(NaN == NaN);

//false
console.log(NaN === NaN);

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

//true
console.log(Object.is(NaN,NaN));

把对象的属性复制到另外一个对象里

'use strict';

let userInfo={};

Object.assign(userInfo,{userName:'rc',password:'123'});

//{userName: "rc", password: "123"}
console.log(userInfo);

设置对象的Prototype

'use strict';


let username = {
    getUserName() {
        return 'rc';
    }
};

let password = {
    getPassword() {
        return '123';
    }
};

let userInfo =Object.create(username);
//rc
console.log(userInfo.getUserName());
//true
console.log(Object.getPrototypeOf(userInfo)===username);

proto

'use strict';


let username = {
    getUserName() {
        return 'rc';
    }
};

let password = {
    getPassword() {
        return '123'; 
    }
};

let userInfo = {
    __proto__: username
};
//rc
console.log(userInfo.getUserName());
//true
console.log(Object.getPrototypeOf(userInfo) === username);

userInfo.__proto__ = password;

//123
console.log(userInfo.getPassword());
//true
console.log(Object.getPrototypeOf(userInfo) === password);

super

'use strict';


let username = {
    getUserName() {
        return 'rc';
    }
};

let user ={
  __proto__:username,
  getUserName(){
      return super.getUserName()+"123";
  }
};
//rc123
console.log(user.getUserName());

迭代器

'use strict';

function chef(foods) {
    let i = 0;
    return {
        next() {
            let done = (i >= foods.length);
            let value = !done ? foods[i++] : undefined;
            return {
                value: value,
                done: done,
            }
        }
    }
}

let rc = chef(['🍎', '🍊']);

//{value: "🍎", done: false}
console.log(rc.next());

//{value: "🍊", done: false}
console.log(rc.next());

//{value: undefined, done: true}
console.log(rc.next());

生成器

'use strict';

function* chef(foods) {
    // yield '🍎';
    // yield '🍊';

    for (let i = 0; i < foods.length; i++) {
        yield foods[i];
    }
}

let rc = chef(['🍎','🍊']);

//{value: "🍎", done: false}
console.log(rc.next());

//{value: "🍊", done: false}
console.log(rc.next());

//{value: undefined, done: true}
console.log(rc.next());

'use strict';

class User {
    constructor(userName) {
        this.userName = userName;
    }

    getUserName() {
        console.log(this.userName);
    }
}

let userInfo = new User("rc");
//rc
userInfo.getUserName();

get与set

'use strict';

class User {
    constructor() {
        this.userName = [];
    }

    get user() {
        return this.userName;
    }

    set user(userName) {
        this.userName.push(userName);
    }
}

let userInfo = new User();
userInfo.user="张三";
userInfo.user="李四";
//["张三", "李四"]
console.log(userInfo.user);


静态方法static

'use strict';

class User {
  static printUser(user){
      console.log(user);
  }
}


//静态方法不需要实例化类
//rc
User.printUser('rc');


继承 extend

'use strict';

class Person {
    constructor(name, age) {
        this.name=name;
        this.age=age;
    }

    info(){
        return `${this.name},${this.age}`
    }
}

class Rc extends  Person{
    constructor(name,age){
        super(name,age)
    }
}

//Rc {name: "rc", age: "18"}
console.log(new Rc("rc","18"));


Set

'use strict';

let userNames = new Set(['张三', '李四', '王五', '张三']);


//Set(3) {"张三", "李四", "王五"}
console.log(userNames);

userNames.add('rc');

//Set(4) {"张三", "李四", "王五", "rc"}
console.log(userNames);

//true
console.log(userNames.has('rc'));

//true
console.log(userNames.delete('rc'));


//张三
//李四
// 王五
userNames.forEach(user => {
    console.log(user)
});

userNames.clear();

//Set(0) {}
console.log(userNames);





Map

'use strict';

let food = new Map();

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


food.set(fruit, '苹果');
food.set(cook, '🍴');
food.set(dessert, '甜点');

console.log(food);
console.log(food.size);
console.log(food.get(fruit));

food.delete(dessert);

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

food.forEach(((value, key) => {
    console.log(`${key}==${value} `)
}));

相关文章

  • Ant Design Pro的知识储备

    Less 笔记 Less 官方文档 ReactJs笔记 ReactJs官方文档 ES6笔记 ES6文档 dvaJs...

  • [总结]ES6 Array

    学习es6时做得小笔记

  • ES6_note

    ES6笔记 es6 - 解构 数组的 解构赋值 let [a, b, c] = [1, 2, 3]; 这种写法属于...

  • Node.js笔记七:es6

    Node.js笔记七:es6 es6是javascript的新一代语法规范,现在很多新的库都是基于新的es6语法规...

  • ES6 笔记(常量&&变量)

    ES6 笔记(常量&&变量) 变量&&常量 新特性 ES6 新增了let命令,用来声明变量。它的用法类似于var,...

  • 1、let和const命令

    阮一峰《ES6 标准入门》 笔记阮一峰 博客案例 在ES6中,我们通常实用 let 表示变量,const 表示常量...

  • let 和 const 命令

    ES6学习笔记1、let命令ES6中新增了let,用于声明变量,与var类似,但let声明只是在其block(块)...

  • 2.let 和 const 命令

    阮一峰ES6教程学习笔记原文地址 1. let和var let:ES6 新增命令用法类似于var,但是所声明的变量...

  • 《深入理解ES6》学习笔记(第一天)

    《深入理解ES6》学习笔记(第一天) 关于本书 深入理解ES6的特性对于所有JavaScript开发人员来说至关重...

  • ES6 let命令和const命令

    基于ES6标准入门(第3版)这本书的笔记要学习angula,vue,react等新的前端框架,必须先熟悉ES6的语...

网友评论

      本文标题:ES6笔记

      本文链接:https://www.haomeiwen.com/subject/neibnqtx.html