1、说出至少5个ES6的新特性,并简述它们的作用。(简答题)

1.let关键字,用于声明只在块级作用域起作用的变量;

2.const关键字,用于声明一个常量;

3.结构赋值,一种新的变量赋值方式。常用于交换变量值,提取函数返回值,设置默认值;

4.Symbol数据类型,定义一个独一无二的值;

5.Proxy代理,用于编写处理函数,来拦截目标对象的操作;

6.for...of遍历,可遍历具有iterator接口的数据结构;

7.Set结构,存储不重复的成员值的集合;

8.Map结构,键名可以是任何类型的键值对集合;

9.Promise对象,更合理、规范地处理异步操作;

10.Class类定义类和更简便地实现类的继承;

2、使用结构赋值,实现两个变量的值的交换(编程题)

let a = 1;let b = 2;

[a,b] = [b,a];

3、使用结构赋值,完成函数的参数默认值(编程题)

function demo({name="王德发"}){console.log(name)};

4、利用数组推导,计算出数组[1,2,3,4]每一个元素的平方并组成新的数组(编程题)

var arr1 =  [1,2,3,4】;

var arr2 = [for(i of arr1) i * i];

console.log(arr2);

5、使用模板字符串改写下面的代码。(ES5 to ES6改写题)

ES5:

let iam = "我是";

let name = "huhu";

let str = "大家好," +  iam + name + ",多指教。";

ES6:

let iam = `我是`;

let name = `huhu`;

let str = `大家好,$( iam + name ),多指教。`

6、用对象的简洁表示法改写下面的代码。(ES5 to ES6改写题)

ES5:

let name = "huhu";

let obj = {

  "name":name,

  "say":function(){

     alert("Hello world");

   }

}

ES6:

let name = "huhu";

let obj = {

  name,

  say(){

    alert('hello world');

  }

}

7、用箭头函数的形式改写下面的代码。(ES5 to ES6改写题)

ES5:

arr.forEach(function(v,i) {

  console.log(i);

  console.log(v);

});

ES6:

arr.forEach((v,i) => {

  console.log(i);

  console.log(v);

})

8、设计一个对象,键名的类型至少包含一个symbol类型,并且实现遍历所有key。(编程题)

let name = Symbol('name');

let product = {

  [name]:"洗衣机",

  "price":799

};

Reflect.ownKeys(product);

9、有一本书的属性为:{"name":"《ES6基础系列》","price":56};要求使用Proxy对象对其进行拦截处理,name属性对外为"

《ES6入门到懵逼》",price属性为只读。(练习题)

let book  = {  "name":"《ES6基础系列》",  "price":56};let proxy = new Proxy(book,{  get:function(target,property){     if(property === "name"){        return "《入门到懵逼》";
           }else{        return target[property];
         }  },      set:function(target,property,value){        if(property === 'price'){
            target[property] = 56;
        }
    }
  });10、关于Set结构,阅读下面的代码,回答问题。let s = new Set();s.add([1]);s.add([1]);console.log(s.size);打印出来的size的值是多少?打印出来的size值是2,如果想回答是1的,多必是记得Set结构是不会存储相同的值。其实在这个案例中,两个数组 [1] 并不是同一个值,它们分别定义的数组,在内存中分别对应着不同的存储地址,因此并不是相同的值。所以都能存储到Set结构中,size为2;

11、关于Map结构, 阅读下面的代码,回答问题。(代码阅读题)let map = new Map();map.set([1],"ES6系列");let con = map.get([1]);console.log(con);问:打印出来的变量 con 的值是多少,为什么?答:undefined。因为set的时候用的数组 [1] 和 get的时候用的数组 [1] 是分别两个不同的数组,只不过它们元素都是 1。它们是分别定义的两个数组,并不是同一个值。新手避免在这里犯错。       如果想达到预期的效果,你要保证 get 的时候和 set的时候用同一个数组。比如:let map = new Map();let arr = [1];map.set(arr,"ES6系列");let con = map.get(arr);console.log(con); // ES6系列

12、定义一个类 Animal,通过传参初始化它的类型,如:“猫科类”。它有一个实例方法:run,run函数体内容可自行定义。class Animal{  constructor(type){    this.type = type;  },  run(){    alert("I can run");  }}

13、基于第12题的Animal类,定义一个子类Cat并继承Animal类。初始化Cat类的昵称name和年龄age。并拥有实例方法eat,eat函数体内容可自行定义。  class Cat extends Animal{    constructor(type,name,age){      super(type);      this.name = name;      this.age = age;    },    eat(){      alert('I am eating');    }  }

ES6面试题总结的更多相关文章

  1. es6面试题--Promise相关

    1. const promise = new Promise((resolve, reject) => { console.log(); resolve(); console.log(); }) ...

  2. 前端面试题总结(js、html、小程序、React、ES6、Vue、算法、全栈热门视频资源)

    写在前面 参考答案及资源在看云平台发布,如果大家想领取资源以及查看答案,可直接前去购买.一次购买永久可看,文档长期更新!有什么意见与建议欢迎您及时联系作者或留言回复! 文档描述 本文是关注微信小程序的 ...

  3. js经典试题之ES6

    js经典试题之ES6 1:在ECMAScript6 中,Promise的状态 答案:pending  resolved(fulfilled) rejected 解析: Promise对象只有三种状态: ...

  4. 深入理解ES6箭头函数的this以及各类this面试题总结

    ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取this的特性,俘获了大批粉丝儿 它也可能是面试中的宠儿, 我们关键要搞清楚 箭头函数和普通函数中的this 一针见血式总结: 普通函数中的 ...

  5. ES6深入浅出-1 新版变量声明:let 和 const-3.视频 相关面试题

    执行顺序问题 请问console.log输出的值是多少 输出的肯定是1 假如这里有一行未知的代码 会打印出几? 如果这段未知的代码是a=2.那么其实console输出的就是2 只关心代码,没有关心代码 ...

  6. 56 道高频 JavaScript 与 ES6+ 的面试题及答案

    56 道高频 JavaScript 与 ES6+ 的面试题及答案 :https://segmentfault.com/a/1190000020082089?utm_source=weekly& ...

  7. (转载) 深入理解ES6箭头函数的this以及各类this面试题总结

    声明:本文转载自 https://blog.csdn.net/yangbingbinga/article/details/61424363 ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取 ...

  8. 前端面试题整理—ES6篇

    1.es5和es6的区别,说一下你所知道的es6 ECMAScript5,即ES5,是ECMAScript的第五次修订,于2009年完成标准化 ECMAScript6,即ES6,是ECMAScript ...

  9. 常见的js算法面试题收集,es6实现

    1.js 统计一个字符串出现频率最高的字母/数字 let str = 'asdfghjklaqwertyuiopiaia'; const strChar = str => { let strin ...

随机推荐

  1. Java知多少(上)

    Java知多少(1)语言概述 Java知多少(2)虚拟机(JVM)以及跨平台原理 Java知多少(3) 就业方向 Java知多少(4)J2SE.J2EE.J2ME的区别 Java知多少(5) Java ...

  2. Numpy 定义矩阵的方法

    import numpy as np #https://www.cnblogs.com/xzcfightingup/p/7598293.html a = np.zeros((2,3),dtype=in ...

  3. Unity场景渲染相关实现的猜想

    如下,很简单的一个场景,一个Panel,二个Cube,一个camera,一个方向光,其中为了避免灯光阴影的影响,关掉阴影,而Panel和二个Cube都是默认的材质,没做修改,我原猜,这三个模型应该都动 ...

  4. Windows平台使用RMAN命令自动删除Oracle过期归档日志的方法

    自动删除Oracle过期归档日志的思路如下: 1.编写自动执行的bat脚本文件: 2.Windows设置定期执行计划 OracleArchLogClear.bat D:/Oracle/product/ ...

  5. [Unity3D] 05 - Access to DB or AWS

    可以选择连接本地服务器,或者云服务器. 参考源代码 : https://www.cnblogs.com/wuzhang/p/wuzhang20141202.html (1) 功能:点击一下按键,然后访 ...

  6. 【代码审计】XYHCMS V3.5任意文件下载漏洞分析

      0x00 环境准备 XYHCMS官网:http://www.xyhcms.com/ 网站源码版本:XYHCMS V3.5(2017-12-04 更新) 程序源码下载:http://www.xyhc ...

  7. 装饰模式和它在JDK中的实现

    对装饰者模式的一个通俗的理解就是:一个东西A包装了另外一个东西B,A在B的功能基础上又扩展了新的功能,但是对外提供的接口不变 装饰者模式(Decorator)的定义: 动态地给一个对象添加一些额外的职 ...

  8. Pro ASP.NET MVC –第三章 MVC模式

    在第七章,我们将创建一个更复杂的ASP.NET MVC示例,但在那之前,我们会深入ASP.NET MVC框架的细节:我们希望你能熟悉MVC设计模式,并且考虑为什么这样设计.在本章,我们将讨论下列内容 ...

  9. 实用方法 - 解决360Doc文章不能复制的问题(实现不登录直接复制)

    问题: 有时搜索文章的时候看到一些有用的文字,或者在网上搜索一些文献资料,找到需要的部分后,通常都可以使用 Ctrl + C,或者右键复制下来.但有些网站,比如:360个人图书馆(360Doc)会强制 ...

  10. javaWeb的基础知识

    在服务器中,端口号是比较重要的,要学会查看和修改.win7有cmd和任务管理器两种方法.同时区分include动作和指令. <%@ include file="url"> ...