学习记录

根据【合格】前端工程师自检清单开始进行知识排查和巩固-链接

2020.6.27 今日任务 - JS基础篇

  1. 变量和类型
    1.1 规定了几个语言类型
    基础类型: Number, String, Boolean, null, undefined, Symbol(新增), BigInt
    引用类型:Object
    Number:检查是否大小于+-Infinity,可使用常量Number.MAX_VALUE和Number.MIN_VALUE
    双精度浮点数取值范围Number.MIN_SAFE_INTEGER和Number.MAX_SAFE_INTEGER
    BigInt可以用任意精度表示整数。目的是为了安全地存储和操作大整数,甚至可以超过数字的安全整数限制。
通过整数后加n或调用BigInt函数创建。
const bigNum1 = 123n          // 123n
const bigNum2 = BigInt(456)   // 456n

1.2 JavaScript对象的底层数据结构是什么
Hash表结构
hash表也就是根据键能访问到对应存储空间的地址
hash碰撞:不同键值访问到相同hash地址,处理方法-开放定址法,拉链法
1.3 Symbol了在实际开发中的应用并实现
Symbol特点独一无二
常见用法:作用对象属性,定义类的私有属性,创建共享symbol
(实现)
1.4 JavaScript中的变量在内存中的具体存储形式

  • 基础类型使用栈存储;基础类型赋值会从新创建一个基础值。
  • 引用类型使用堆存储;栈中只是存储该对象的在堆中的地址。引用类型赋值只是把堆地址赋给新的变量。
    1.5 理解值类型和引用类型
    区别:
    基本类型的值是一经确定就不可变的,基本类型的比较是值的比较,基本类型的变量是存放在栈区的
    引用类型的值是可变的(可以为引用类型添加属性和方法,也可以删除其属性和方法),引用类型的值是同时保存在栈内存和堆内存中的对象
    栈区内存保存变量标识符和指向堆内存中该对象的指针,也可以说是该对象在堆内存的地址。
    1.6 null和undefined的区别?
    undefined 是 Undefined 类型的值,表示未定义。任何变量在赋值前都是 Undefined 类型,值为 undefined 。由于undefined 只是全局作用域下的一个属性(变量),并非关键字。undefined 属性的属性特性
    Null 类型也只有一个值,就是 null,它的语义表示空值,与 undefined 不同,null 是 JavaScript 关键字,所以在任何代码中,你都可以放心用 null 关键字来获取 null 值。
    1.7 至少可以说出三种判断JavaScript数据类型的方式,以及他们的优缺点,如何准确的判断数组类型
方法 优点 缺点
typeof 简单,对基础类型检测新能好。 只能校验基础类型,而且typeof null === 'object' (JS 设计初的bug)
Object.prototype.toString.call 所有类型都能检测 写起来比较繁琐,性能不如 typeof 好;
instanceof 能检测出引用类型 不能检测出基础类型
constructor 基本能检测所有的类型(除了null和undefined) constructor易被修改,不可靠

https://github.com/mqyqingfeng/Blog/issues/28

1.8 基本类型对应的内置对象,以及他们之间的装箱拆箱操作

  • 装箱转换
    每一种基本类型 Number、String、Boolean、Symbol 在对象中都有对应的类(null, undefined 除外),所谓装箱转换,正是把基本类型转换为对应的对象,它是类型转换中一种相当重要的种类。

注意:

装箱机制会频繁产生临时对象,在一些对性能要求较高的场景下,我们应该尽量避免对基本类型做装箱转换。
Symbol 是不能直接使用 new 操作符调用的。不过我们可以装箱机制得到一个 Symbol 对象。
每一类装箱对象皆有私有的 Class 属性,这些属性可以用 Object.prototype.toString 获取.

    var symbolObject = (function(){ return this; }).call(Symbol("a"));

    console.log(typeof symbolObject); //object
    console.log(symbolObject instanceof Symbol); //true
    console.log(symbolObject.constructor == Symbol); //true

    // ==== 也可以使用 Object 函数显示调用装箱能力;
    var symbolObject = Object(Symbol("a"));

    console.log(Object.prototype.toString.call(symbolObject)); //[object Symbol]
  • 拆箱转换
    在 JavaScript 标准中,规定了 ToPrimitive 函数,它是对象类型到基本类型的转换(即,拆箱转换)。

对象到 String 和 Number 的转换都遵循“先拆箱再转换”的规则。通过拆箱转换,把对象变成基本类型,再从基本类型转换为对应的 String 或者 Number。

拆箱转换会尝试调用 valueOf 和 toString 来获得拆箱后的基本类型。如果 valueOf 和 toString 都不存在,或者没有返回基本类型,则会产生类型错误 TypeError。

String 类型会优先调用 toString ;

在 ES6 之后,还允许对象通过显式指定 @@toPrimitive Symbol 来覆盖原有的行为。

    var o = {
        valueOf : () => {console.log("valueOf"); return {}},
        toString : () => {console.log("toString"); return {}}
    }

    o * 2
    // valueOf
    // toString
    // TypeError

    String(o)
    // toString 
    // valueOf 
    // TypeError

    o[Symbol.toPrimitive] = () => {console.log("toPrimitive"); return "hello"} console.log(o + "") // t

1.9 可能发生隐式类型转换的场景以及转换原则,应如何避免或巧妙应用
编码时应尽可能地将类型转换表达清楚,以免给别人留坑。类型转换越清晰,代码可读性越高,更容易理解。

  • 运算符 - * / 强制将其他类型转化为数字类型
    == 宽松 (loose equals ) 类型转换(ps: 不建议使用,规则真心有点复杂,感兴趣可以去看下 《你不知道的JavaScript 中卷》 1.4章)

隐式强制类型转换为布尔值

  • if(...)语句中的条件判断表达式
  • for(...;...;...)语句中的条件判断表达式(第二个)
  • while(...) 和 do...while(...) 循环中的条件判断表达式
  • ?: 中的条件判断表达式
  • 逻辑运算符 || 和 && 左边的操作数
类型 Null Undefined Boolean(true) Boolean(false) Number String Symbol Object
Boolean false false - - [0, NaN] - false true ''-false true true true
Number 0 NaN 1 0 - StringToNumber 拆箱操作
String 'null' 'undefined' 'true' 'false' NumberToString - TypeError 拆箱操作
Object TypeError TypeError 装箱操作 装箱操作 装箱操作 装箱操作 装箱操作 -

1.10 出现小数精度丢失的原因,JavaScript可以存储的最大数字、最大安全数字,JavaScript处理大数字的方法、避免精度丢失的方法
https://github.com/camsong/blog/issues/9

https://github.com/mqyqingfeng/Blog

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