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. 使用grep查找字符串

    如下: grep -r 'target string' --exclude='pattern' dir/ 例子: grep -r Debug --exclude='*.js' ./ 查找本目录下除了j ...

  2. IntelliJ IDEA下spring boot项目打包

    Spring Boot自带Tomcat插件,可以直接编写启动类,开启Tomcat服务 springboot适合前后端分离,打成jar进行部署更合适 application.properties配置端口 ...

  3. android 编程之 PopupWindow 窗口的弹出

    PopupWindow 是一个可以显示在当前 Activity 之上的浮动容器,PopupWindow 弹出的位置是能够改变的,按照有无偏移量,可以分为无偏移和有偏移两种:按照参照对象的不同又可以分为 ...

  4. Android异步处理系列文章四篇之三

    Android异步处理一:使用Thread+Handler实现非UI线程更新UI界面Android异步处理二:使用AsyncTask异步更新UI界面Android异步处理三:Handler+Loope ...

  5. android基础---->SQLite数据库的使用

    SQLite 一个非常流行的嵌入式数据库,它支持 SQL 语言,并且只利用很少的内存就有很好的性能.此外它还是开源的,任何人都可以使用它.许多开源项目((Mozilla, PHP, Python)都使 ...

  6. 深度学习之windows安装tensorflow

    1. 安装python3.5 2. 下载tensorflow-1.1.0rc2-cp35-cp35m-win_amd64.whl 3. pip install tensorflow-1.1.0rc2- ...

  7. 深入理解 Java 虚拟机之学习笔记(1)

    本书结构: 从宏观的角度介绍了整个Java技术体系.Java和JVM的发展历程.模块化,以及JDK的编译 讲解了JVM的自动内存管理,包括虚拟机内存区域的划分原理以及各种内存溢出异常产生的原因 分析了 ...

  8. [原]Jenkins(七)---jenkins项目编译测试发布由maven构建的web项目

    /** * lihaibo * 文章内容都是根据自己工作情况实践得出. * 版权声明:本博客欢迎转发,但请保留原作者信息! http://www.cnblogs.com/horizonli/p/533 ...

  9. 客户端TortoiseSVN的安装及使用方法 (申明:来源于网络)

    客户端TortoiseSVN的安装及使用方法 (申明:来源于网络) 地址:http://blog.chinaunix.net/uid-27004869-id-4112057.html

  10. IIS8.5 Error Code 0x8007007e HTTP 错误 500.19的解决方法

    window server 2012R2 IIS8.5 引用:https://www.52jbj.com/yunying/340443.html HTTP 错误 500.19 - Internal S ...