ES6面试题总结
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面试题总结的更多相关文章
- es6面试题--Promise相关
1. const promise = new Promise((resolve, reject) => { console.log(); resolve(); console.log(); }) ...
- 前端面试题总结(js、html、小程序、React、ES6、Vue、算法、全栈热门视频资源)
写在前面 参考答案及资源在看云平台发布,如果大家想领取资源以及查看答案,可直接前去购买.一次购买永久可看,文档长期更新!有什么意见与建议欢迎您及时联系作者或留言回复! 文档描述 本文是关注微信小程序的 ...
- js经典试题之ES6
js经典试题之ES6 1:在ECMAScript6 中,Promise的状态 答案:pending resolved(fulfilled) rejected 解析: Promise对象只有三种状态: ...
- 深入理解ES6箭头函数的this以及各类this面试题总结
ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取this的特性,俘获了大批粉丝儿 它也可能是面试中的宠儿, 我们关键要搞清楚 箭头函数和普通函数中的this 一针见血式总结: 普通函数中的 ...
- ES6深入浅出-1 新版变量声明:let 和 const-3.视频 相关面试题
执行顺序问题 请问console.log输出的值是多少 输出的肯定是1 假如这里有一行未知的代码 会打印出几? 如果这段未知的代码是a=2.那么其实console输出的就是2 只关心代码,没有关心代码 ...
- 56 道高频 JavaScript 与 ES6+ 的面试题及答案
56 道高频 JavaScript 与 ES6+ 的面试题及答案 :https://segmentfault.com/a/1190000020082089?utm_source=weekly& ...
- (转载) 深入理解ES6箭头函数的this以及各类this面试题总结
声明:本文转载自 https://blog.csdn.net/yangbingbinga/article/details/61424363 ES6中新增了箭头函数这种语法,箭头函数以其简洁性和方便获取 ...
- 前端面试题整理—ES6篇
1.es5和es6的区别,说一下你所知道的es6 ECMAScript5,即ES5,是ECMAScript的第五次修订,于2009年完成标准化 ECMAScript6,即ES6,是ECMAScript ...
- 常见的js算法面试题收集,es6实现
1.js 统计一个字符串出现频率最高的字母/数字 let str = 'asdfghjklaqwertyuiopiaia'; const strChar = str => { let strin ...
随机推荐
- Java知多少(47)多重catch语句的使用
某些情况,由单个代码段可能引起多个异常.处理这种情况,你可以定义两个或更多的catch子句,每个子句捕获一种类型的异常.当异常被引发时,每一个catch子句被依次检查,第一个匹配异常类型的子句执行.当 ...
- eclipse java ee jsp tomcat Server文件夹给删了,怎么办?
右键 选择属性 选择Switch location 就可以了
- [PGM] Variable elimination and Belief propagation
内容范围如题.Lec 08-11的内容:https://www.youtube.com/watch?v=Qa04kw1gKHk&index=36&list=PLQiVpyxVlLkbp ...
- 【netcore基础】MVC API全局异常捕捉中间件ExceptionHandlerMiddleWare
项目中想通过统一的接口格式返回异常信息,而不是404 500等HTTP协议层的异常响应 例如 { , , "message":"用户名或密码不正确", &quo ...
- H5网页适配 iPhoneX,就是这么简单(转)
iPhoneX 取消了物理按键,改成底部小黑条,这一改动导致网页出现了比较尴尬的屏幕适配问题.对于网页而言,顶部(刘海部位)的适配问题浏览器已经做了处理,所以我们只需要关注底部与小黑条的适配问题即可( ...
- openresty的安装和使用
1,简介 OpenResty(又称:ngx_openresty) 是一个基于 NGINX 的可伸缩的 Web 平台,是一个强大的 Web 应用服务器,在性能方面,OpenResty可以 快速构造出足以 ...
- 10.19stark组件开发(三)
2018-10-19 15:42:15 2018-10-19 18:21:33 我觉得现在主要是学一种解决问题的思路,也就是逻辑或者说是算法!!!! 要有对代码的感触!要用面向对象对类进行封装!!Dj ...
- emmet前端模板
https://github.com/emmetio/emmet/blob/master/lib/snippets.json "emmet.extensionsPath": &qu ...
- centos 7 配置hadoop与spark
cd /home mkdir shixi_enzhaocd shixi_enzhaomkdir suaneccd suanecmkdir installsmkdir libsmkdir scripts ...
- PHP数组(数组正则表达式、数组、预定义数组)
正则表达式 1.替换 $s = "hello5world"; $s = preg_replace("/\d/","#",$s); echo ...