ES6进阶之路

gavinjay 2018-09-04 原文

ES6进阶之路

1.说出至少5个ES6的新特性,并简述它们的作用。

1、 let关键字,用于声明只在块级作用域起作用的变量。
2、 const关键字,用于声明一个常量。
3、 结构赋值,一种新的变量赋值方式。常用于交换变量值,提取函数返回值,设置默认值。
4、 Symbol数据类型,定义一个独一无二的值。
5、 Proxy代理,用于编写处理函数,来拦截目标对象的操作。
6for...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.使用模板字符串改写下面的代码

let iam = "我是";
let name = "前端君";
let str = "大家好,"+iam+name+",多指教。";
改写成:
let iam  = `我是`;
let name = `前端君`;
let str  = `大家好,${iam+name},多指教。`;

6.用对象的简洁表示法改写下面的代码

let name = "前端君";
let obj = {
   "name":name,
   "say":function(){
       alert('hello world');
   }
};
改写成:
let name = "前端君";
let obj = {
   name,
   say(){
       alert('hello world');
   }
};

7.用箭头函数的形式改写下面的代码。

arr.forEach(function (v,i) {
   console.log(i);
   console.log(v);
});
改写成:
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.阅读下面的代码,并用for…of改成它。

let arr = [11,22,33,44,55];
let sum = 0;
for(let i=0;i<arr.length;i++){
   sum += arr[i];
}
改写:
let arr = [11,22,33,44,55];
let sum = 0;
for(value of arr){
   sum += value;
}

11.关于Set结构,阅读下面的代码,回答问题。。

let s = new Set();
s.add([1]);
s.add([1]);
console.log(s.size);
问:打印出来的size的值是多少?

 

答:2。如果回答为1的同学,多必是记得Set结构是不会存储相同的值。
其实在这个案例中,两个数组[1]并不是同一个值,它们分别定义的数组,
在内存中分别对应着不同的存储地址,因此并不是相同的值。
所以都能存储到Set结构中,size为2。

12.关于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);
这样的得到的变量con的值就是:“ES6系列”。

13.定义一个类Animal,通过传参初始化它的类型,如:“猫科类”。它有一个实例方法:run,run函数体内容可自行定义。

class Animal {
   constructor(type){
       this.type = type;
   }

   run(){
       alert('I can run');
   }
}

14.基于第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');
   }
}

15.利用module模块,实现两个模块A和B,A模块导出变量name,age和say方法。B模块只导入变量name和say方法,并且重命名name为nickname。

答:
//-----模块A-------//
var name = "kitty";
var age = 15;
var say = function(){
   //....
};
export {name,age,say}
 
//---module-B.js文件---
import { name as nickname, say } from "模块A的相对路径";

 

posted on 2018-09-04 19:57 GavinJay 阅读() 评论() 编辑 收藏

 

 
版权声明:本文为gavinjay原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://www.cnblogs.com/gavinjay/p/9588136.html

ES6进阶之路的更多相关文章

  1. js 创建对象几种方式

    在js中创建对象的方法可分为6种,分别是:基本模式、工厂模式、构造函数模式、原型模式、组合模式、动态原型模式, […]...

  2. 我所理解的前端

    入坑前端到今天也将近两年半了,这两天突然想到了第一次面试时面试官的一个问题——-你怎样 […]...

  3. js div的显示和隐藏

    <head>    <title></title>    <styl […]...

  4. js万亿级数字转汉字的封装方法

    要求如图: 实现方法: function changeBillionToCN(c) { // 对传参进行类型处 […]...

  5. Promise原理详解

    参考文章:深入理解 Promise、【翻译】Promises/A+规范 从入门Promise的正确姿势中我们已 […]...

  6. 偏前端 – vue-cli(axios请求数据==》token+按接口参数顺序(参数值拼接base64)-> MD5)

     token+按接口参数顺序(参数值拼接base64)-> MD5)   请教于“喵咪”,再此特别鸣谢! […]...

  7. 个人JS体系整理(三)

     一. 严格模式 JavaScript 严格模式(strict mode)即在严格的条件下运行。首先声明,严格 […]...

  8. 适用于nodercms的打包构建脚本

    适用于nodercms的打包构建脚本 Posted on 2019-03-28 16:22 Bowen Hua […]...

随机推荐

  1. 「HTML+CSS」–自定义加载动画【008】

    前言 Hello!小伙伴! 首先非常感谢您阅读海轰的文章,倘若文中有错误的地方,欢迎您指出~ 哈哈 自我介绍一 […]...

  2. 2019 年 6 月编程语言排行榜

    TIOBE 公布了 2019 年 6 月编程语言排行榜,其中 Python 的 TIOBE 指数为 8.5%, […]...

  3. PDF 文件编辑修改与格式转换

    PDF 文件编辑修改与格式转换      将pdf文件导出转换为doc、txt的软件网上很多,然而pdf格式的 […]...

  4. 免费视频格式转换工具 – 钱廷柱

    免费视频格式转换工具     免费视频格式转换工具 Video Convertor 1.0 [2012-2-1 […]...

  5. 关于在CentOS上解压含有中文名的ZIP文件出现乱码的解决办法 – SwenChan

    关于在CentOS上解压含有中文名的ZIP文件出现乱码的解决办法 今天在学校做实验需要解压缩一些范例程序,我准 […]...

  6. 手机号名字替换*号

    手机号名字替换*号 名字替换*号/** * @param $str 字符串 * @param $start 替 […]...

  7. 共享内存的疑惑

    共享内存的疑惑...

  8. 【Qt开发】更改应用程序图标和任务栏图标

    说明 实际开发过程中,生成的应用文件不会用默认的图标,同时程序启动后任务栏的图标也需要修改,还有窗口的图标,这 […]...

展开目录

目录导航