13 丁老师讲解 es6练习题

  1. es 全称是? ECMAscript
  1. es6之前的作用域有哪些?
  • 全局作用域
  • 函数作用有
  1. es6引入了什么作用域?
  • 块级作用域
  1. let 和 var的区别?
  • let在同一作用域下,不得重复声明
  • let 存在暂时性死区
  • let 无法变量提升

遗漏: let 能够识别块级作用域,这是核心..

  1. set 和 map 的数据结构的区别,底层实现原理是什么?
  • set 只存 value 类似数组?
  • map 存 key value 类似对象?
  • 底层实现原理是 用哈希值计算分类进不同的"桶",
  • 分配进每个桶的,用邻接链表
  • set 产生类似数组的结构, 里面的值唯一
  • map 做字典
  1. 如何判断链表里有环?
  • 链表里有环的意思是有单位指向序列前面的单位.
  • 第一种, 进行遍历, 如果无限循环,就表明有环(哈哈哈,这么答是不是肯定不行?)
  • 第二种, 进行遍历,将遍历过的单位放进一个数组里,放进数组之前判断是否已经在数组里存在, 如果全部遍历不存在,表明没有环,如果存在,就表明有环.
  • 不过这种方法在数据量比较大的时候,似乎很没效率,

链表和数组的区别
链表 地址是 非连续的, 数组的内存是 连续的.
邻接链表
判断有没有环

  • 取一个步长为一, 取一个步长为二 的 指针
  • 如果出现两个指针相同, 且不为空, 则表明形成环了.
  • 如果形成环, 只要两个指针速度不同,一直绕圈,就会碰到. 好聪明.
  1. 判断this指向.
    箭头函数没有this 会绑定最近的非箭头函数作用域中的this
    所以下面的都指向 window?
let show = () => {
  console.log(this)
}
let obj = {show}
obj.show();/ window
obj.otherShow = show.bind(obj);/window
obj.otherShow();/window
let newObj = new obj.otherShow;/window/ 错了 这里应该会报错.

这道题错得令人羞愧,

  1. 原生的继承怎么写?

function Father () {};
function Son () {};
1. 圣杯模式
function temp () {};
temp.prototype = Father.prototype;
Son.prototype = new temp();

2. 也是圣杯模式?
Son.prototype = Object.create(Father.prototype);

3. 
Object.setPrototypeOf(Son.prototype,Father.prototype);

4.这种好像不太好, 语义上最好不要动 __proto__?
Son.prototype.__proto__ = Father.prototype;

以上都是实现原型继承,不是实例继承 
  1. ES6中的class关键字声明的类具有什么特性?
  • 不能重复声明
  • 存在暂时性死区
  • 变量声明不提升
  • 必须new 的方式执行 不得直接执行
  1. 判断字符串中时候包含哪个字符用什么方法?ES中引入了includes,利
    用原生语法实现字符串的 includes的功能
  • 可以用 includes, 也可以用 indexOf, lastIndexOf
  • 如果转成数组还可以用 find?
  • 可以用正则?
String.prototype.myIncludes = function (txt) {
  let reg = new RegExp(txt);
    return reg.test(this);
}

  1. 如果想让 arguments,NodeLists以及likeArray这样的类数组,如何使
    用数组的方法,有几种?
  • 之前最常用的是 [].slice.call(arguments)
  • 类似的也可以用 [].concat(arguments)
  • es6中的数组扩展符, [...arguments]
  • 好像还有一个静态方法 Array.from(arguments);
  • 最基础的也可以用 for 循环
  1. 阐述结构赋值的好处
  • 这我才刚学,,也没用过几回啊.
  • 不会说就先来一句这个
  • 节省代码量, 语义化更好
  1. 通过结构赋值取出下面对象中的特定的值
    结构赋值,关键是要分清哪个是赋值,哪个是默认值, 哪个是模式, 哪个是变量
let movieList = {
  start: 0,
  count: 1,
  subjects: [{
    rating: {
      max: 10,
      min: 0,
      average: 9.6,
    },
    genres: ['剧情', '喜剧'],
    casts: 1,
    title: '我不是药神',
  }]
}
取出里面的 subjects, rating, average, 剧情, 喜剧, 结构

let {
  subjects,
  subjects : [{
    rating,
    rating : {
      average
    },
    genres:[juqing,xiju]
  }]} = movieList
  1. 利用Promise实现以下需求:
    我们需要做基于三个异步请求任务 A,B,C之后,把他们的返回结果都拿到之
    后,经过简单处理之后在发送最后一次请求,最终得到请求之后的结果。
    (异步请求用setTimeOut模拟)

感觉应该是考察 Promise.all()

      let p1 = new Promise((res, rej) => {
        setTimeout(() => {
          if(Math.random() - 0.5 > 0) {
            res('123');
          } else {
            rej('-123');
          }
        }, 1000)
      })
      let p2 = new Promise((res, rej) => {
        setTimeout(() => {
          if(Math.random() - 0.5 > 0) {
            res('223');
          } else {
            rej('-223');
          }
        }, 2000)
      })
      let p3 = new Promise((res, rej) => {
        setTimeout(() => {
          if(Math.random() - 0.5 > 0) {
            res('323');
          } else {
            rej('-323');
          }
        }, 3000)
      })

      Promise.all([p1, p2, p3]).then((data) => {
        let sub = "";
        sub = data.reduce((sub, item) => {
          return sub += item;
        })

        return new Promise((res, rej) => {
          setTimeout(() => {
            res(sub + sub);
          }, 1000);
        })

      }, (err) => {
        console.log(err)
      }).then((data) => {
        console.log(data)
      })
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容

  • [TOC] 参考阮一峰的ECMAScript 6 入门参考深入浅出ES6 let和const let和const都...
    郭子web阅读 1,767评论 0 1
  • 一、ES6简介 ​ 历时将近6年的时间来制定的新 ECMAScript 标准 ECMAScript 6(亦称 ...
    一岁一枯荣_阅读 6,037评论 8 25
  • 前面的话 函数是所有编程语言的重要组成部分,在ES6出现前,JS的函数语法一直没有太大的变化,从而遗留了很多问题,...
    CodeMT阅读 808评论 0 1
  • 树绿花红水尽头,草盛柳亦柔,过西楼。雨吞碧叶绿如油,莺纷走,风过暗香游。 林静路清幽,久将春日候,醉消愁。独临水榭...
    青木书生阅读 318评论 0 5
  • 彷彿每次的分享開頭都是時間過去了一大半,然後自己還沒拿到自己想要的成績。 是的,時間唰唰的過的飛快,我成長的腳步越...
    Lucie陸陸阅读 144评论 0 0