webveuje/zuoye/jq es6/es6.md
2021-04-29 17:16:40 +08:00

105 lines
3.1 KiB
Markdown
Raw Blame History

This file contains ambiguous Unicode characters

This file contains Unicode characters that might be confused with other characters. If you think that this is intentional, you can safely ignore this warning. Use the Escape button to reveal them.

# es6 相关
1. 下面这个例子最外面会输出10 如何解决
```
for(var i = 0; i < 10; i++) {
console.log(1);
}
console.log(i);
```
2. 使用结构赋值实现两个变量的值的交换
3. 使用结构赋值完成函数的参数默认值
4. 利用数组推导计算出数组 [1,2,3,4] 每一个元素的平方并组成新的数组
5. 使用模板字符串改写下面的代码。(ES5 to ES6改写题
```
letname ="前端研究所";
letobj = {
"name":name,
"say":function(){
alert('hello world');
}
};
```
6. 用箭头函数的形式改写下面的代码。(ES5 to ES6改写题
```
arr.forEach(function(v,i) {
console.log(i);
console.log(v);
});
```
7. 设计一个对象键名的类型至少包含一个symbol类型并且实现遍历所有key
8. 有一本书的属性为{“name:“《ES6基础系列》”, price”:56 }要求使用Proxy对象对其进行拦截处理name属性对外为“《ES6入门到懵逼》”,price属性为只读。(练习题
9. 阅读下面的代码并用for...of改成它。(ES5 to ES6改写题
10. 关于Set结构阅读下面的代码回答问题。(代码阅读题)。
```
lets =newSet();
s.add([1]);
s.add([1]);
console.log(s.size);
```
打印出来的size的值是多少为什么
11. 关于Map结构阅读下面的代码回答问题。(代码阅读题
```
letmap =newMap();
map.set([1],"ES6系列");
letcon = map.get([1]);
console.log(con);
```
打印出来的变量con的值是多少为什么
12. 11题的如何得到的变量con的值就是:“ES6系列”。
13. 通过class 定义一个类Animal通过传参初始化它的类型:“猫科类”。它有一个实例方法runrun函数体内容可自行定义
14. 基于上一题的Animal类定义一个子类Cat并继承Animal类初始化Cat类的昵称name和年龄age并拥有实例方法eateat函数体内容可自行定义
15. 利用module模块实现两个模块A和BA模块导出变量nameage和say方法B模块只导入变量name和say方法并且重命名name为nickname
16. 使用字符串模板 把下面代码补充完整
```
const greetings = (name) => {
return `hello `; //要补充的部分
}
```
17. 使用es6语法 实现下图代码功能
![preview](https://pic2.zhimg.com/v2-73bff89d4cfb706553610dd4725e21e1_r.jpg)
18. 冻结上面17题中定义的对象 使其无法被修改(温馨提示可以用 object.freeze() 简单了解object.freeze()的用法
参考 https://developer.mozilla.org/zh-CN/docs/Web/JavaScript/Reference/Global_Objects/Object/freeze
19. 解释一下 `Object.freeze()``const` 的区别
20. 说明下列方法为何不能用作 IIFE要使其成为 IIFE需要进行哪些更改
```
function foo(){ }();
```
21. 用promise语法封装ajax功能并调用
22. 用await async 改写上面的21题