ECMAScript 和 JavaScript 是什么关系?

  1996 年 11 月,JavaScript 的创造者 Netscape 公司,希望JavaScript能够成为国际标准,将其提交给标准化组织 ECMA。次年,ECMA 发布了ECMAScript 1.0 版。不叫 JavaScript的原因:一是商标,JavaScript 已被 Netscape 公司注册为商标;二是体现其制定者是 ECMA,不是 Netscape,有利于保证其的开放性和中立性。

  

 let 和 const 命令

let声明变量

  块状作用域(任意大括号包含的变量都只在大括号里起作用,超出则报错)

{let a=20;}

console.log(a);//报错

//使用var
var a = []; for (var i = 0; i < 5; i++) { a[i] = function () { console.log(i); }; } a[3](); // 结果为5
//使用let
var a = []; for (let i = 0; i < 5; i++) { a[i] = function () { console.log(i); }; } a[3](); // 结果为3

  不能重复声明

let a=20;

let a=10;

console.log(a);//报错

  没有变量提升

console.log(a);//报错

let a=20;

  暂时性死区(在代码块内,使用let命令声明变量之前,该变量都是不可用的),简称TDZ

var a = 123;

if (true) {

    a = 'abc';

    let a;//在let命令声明变量a之前,都属于变量a的“死区”。

}

const 声明常量(声明一个只读的常量。一旦声明,常量值不可变)

  声明必须同时赋值

const a;

a=20;

console.log(a);//报错

  const 声明与 let 声明一样:无变量提升、块级作用域、暂时性死区、不可重复声明。

字符串的扩展

模板字符串

var y = 2018,m = 5,d = 7;

var str = `今天是${y}年${m}月${d}日`;

部分新方法

var str = "hello";

//判断是否包含某指定的字符

var res1 = str.includes("d");//res1结果为 false

//判断是否以某字符开头

var res2 = str.startsWith("e");//res2结果为 false
//判断是否一某字符结尾 var res3 = str.endsWith("o");//res3结果为 true //让字符串重复几次 var res4 = str.repeat(3);//res4结果为 hellohellohello

函数的扩展

默认值

//函数的默认值

function fn(a,b = 20) {

    console.log(a,b);

}

fn(10);//结果为10 20

剩余参数

//剩余参数

function fn(a,...b) {

    console.log(a,b);

}

fn(10,[2,3,4]);//结果为 

箭头函数

//有参数

var fn1=num=>num;//相当于var fn1=function(num){return num;}
//无参数
var fn2=()=>10;//相当于var fn2=function(){return 10;}
//多个参数
var fn3=(num1,num2)=>num1+mun2;//或者var fn3=(num1,num2)=>{return num1+num2};
//map的用法
[1,2,3].map(num=>num*2);//相当于var fn=[1,2,3].map(function(num){return num*2;});

set方法

Set是一个构造函数,可创建出类似于数组的数据结构一般用于创建不重复的数组

//创建set数组

var arr=new Set([1,2,3]);

//添加数据

arr.add(4);

//删除指定数据

arr.delete(4);//判断数组是否有某指定元素

var res=arr.has(2);//res 结果为 true
//控制台输出数组元素 for(let [key,value] of arr.entries()){ console.log(value); }
//删除所有元素
arr.clear();

promise 的用法

回调函数

function a(callBack) {

    console.log("我是主函数");

    callBack();

}

function b() {

    console.log("我是回调函数")

}

a(b);

多层回调

function run() {

  var obj=new Promise(function (resolve,reject) {

    resolve("运行成功的函数");

    reject("运行失败的函数");

  })

  return obj;

}

run().then(function () {

  //执行一些功能

}).then(function () {

  //再执行一些功能

})

类与继承

class Person{

  constructor(name,age){

    this.name=name;

    this.age=age;

  }

  static tell(){

    alert("hello");

  }

  say(){

    alert(this.name+this.age);

  }

}

var per=new Person("David",23);

console.log(per.name);

per.say();

//static修饰的方法是类直接调用的不能用new出来的对象调用Person.tell();

class Student extends Person{

  constructor(name,age,score){

    super(name,age);

    this.score = score;

  }

  show(){

    alert(this.name + this.score);

  }

}

var stu=new Student("Nancy",24,80);

stu.show();

stu.say();

ECMAScript 6基础的更多相关文章

  1. ECMAScript 初探 - 基础篇

    ECMAScript 语言的标准是由 Netscape.Sun.微软.Borland 等公司基于 JavaScript 和 JScript 锤炼.定义出来的. ECMAScript 仅仅是一个描述,定 ...

  2. ECMAScript 6 基础

    ECMAScript 6 基础 ECMAScript 6 简介 JavaScript 三大组成部分 ECMAScript DOM BOM ECMAScript 发展历史 https://develop ...

  3. ECMAScript 6 基础入门

    0. ECMAScript 与 JavaScript ECMAScript (ECMA 262)是 JavaScript 语言标准的名字,ECMAScript 是标准,JavaScript 是各厂商的 ...

  4. ECMAScript/JS 基础知识讲解

    闭包 下面这个方法能输入0 1 2 ... 9吗?显然是不可以的,输出结果是10个10. function test() { var arr = []; for(var i = 0; i < 1 ...

  5. JavaScript 基础第七天(DOM的开始)

    一.引言 JavaScript的内容分为三个部分,这三个部分分别是ECMAScript.DOM.BOM三个部分组成.所谓ECMAScript就是JavaScript和核心基础语法,DOM是文档对象模型 ...

  6. Nodejs第一天-{Nodejs基础 深刻理解浏览器 环境变量 基础语法}

    Nodejs第一天 1.什么是Nodejs ​ Nodejs是一个可以运行(解析)ECMAScript的环境; ​ ECMAScript是规定了一些列的语法 ,这些语法想要解析的执行就需要放在某个环境 ...

  7. javascript快速入门7--ECMAScript语法基础

    ECMAScript的基础概念 熟悉Java.C和Perl这些语言的开发者会发现ECMAScript的语法很容易掌握,因为它借用了这些语言的语法.Java和ECMAScript有一些关键语法特性相同, ...

  8. css与js基础

    CSS样式 1 宽高设置 块元素可使用 wid 1字体 font-family :  文本类型 font-size     字体大小 font-style 字体样式 斜体italic   正常norm ...

  9. HTML5学堂 全新的HTML5/前端技术分享平台

    HTML5学堂 全新的HTML5/前端技术分享平台 HTML5学堂是做什么的? HTML5学堂~http://www.h5course.com~由多名热爱H5的讲师们组成的一个组织.致力于构建一个前端 ...

随机推荐

  1. 在vue中使用jquery

    首先默认你已经有了一个vue程序,如果你想在vue中使用jquery,那么请继续阅读. 当然,加入你没有一个vue程序,这里也给出创建一个vue程序的命令.当然,你肯定装了vue-cli,不然你不会点 ...

  2. Java8新特性一点通 | 回顾功能接口Functional Interface

    Functional Interface Functional Interface是什么? 功能接口是java 8中的新增功能,它们只允许一个抽象方法.这些接口也称为单抽象方法接口(SAM接口).这些 ...

  3. MyBatis 介绍

    MyBatis 介绍 MyBatis 是一款优秀的 ORM(Object Relational Mapping,对象关系映射)框架,它可以通过对象和数据库之间的映射,将程序中的对象自动存储到数据库中. ...

  4. Java 程序是如何执行的

    Java 程序是如何执行的 了解任何一门语言的精髓都是先俯览其全貌,从宏观的视角把握全局,然后再深入每个知识点逐个击破,这样就可以深入而快速的掌握一项技能.同样学习 Java 也是如此,本节就让我们先 ...

  5. 【大白话系列】MySQL 学习总结 之 初步了解 MySQL 的架构设计

    一.MySQL还是个黑盒子 我们都知道,只要我们系统引入了 MySQL 驱动和连接池,就能从数据库连接池获取一个数据库连接,然后就可以执行增删改查的操作了. 可是我们并不知道 MySQL 里面是怎么执 ...

  6. HanLP《自然语言处理入门》笔记--6.条件随机场与序列标注

    笔记转载于GitHub项目:https://github.com/NLP-LOVE/Introduction-NLP 6. 条件随机场与序列标注 本章介绍一种新的序列标注模型条件随机场.这种模型与感知 ...

  7. IntelliJ IDEA 2020 的Debug功能也太好用了,真香!

    写在前边 作为一个有点强迫症的程序员来说,所有的应用软件.开发工具都必须要升级到最高版本,否则就会很难受到坐立不安.日思夜想.茶饭不思.至于什么时候得的这种病我也记不清了,哈哈哈 IntelliJ I ...

  8. html作业记录

    <html> <head> <title>Hello World</title> </head> <body> <!-- ...

  9. java4选择结构 二

    public class jh_01_为什么使用switch选择结构 { /* * 韩嫣参加计算机编程大赛 * 如果获得第一名,将参加麻省理工大学组织的1个月夏令营 * 如果获得第二名,将奖励惠普笔记 ...

  10. C# WinForm 使用SMTP协议发送QQ邮箱验证码

    文章来自:https://blog.csdn.net/IT_xiao_guang_guang/article/details/104336604 前言   在程序设计中,发送验证码是常见的一个功能,用 ...