知名符号是一些具有特殊含义的共享符号,通过 Symbol 的静态属性得到
ES6 用知名符号暴露了某些场景的内部实现
知名符号都是系统定义好的
如以下例子

instanceof

  1. function a (){
  2. }
  3. const b = new a();

image.png
b instanceof a 等效于aSymbol.hasInstance

Symbol.isConcatSpreadable

该知名符号会影响数组的 concat 方法

  1. const arr = [1]
  2. const arr1 = [5,6,7]
  3. arr1[Symbol.isConcatSpreadable] = false; //改变concat的拼接数组的方法
  4. const result = arr.concat(arr1)

正常效果 现在的效果
image.pngimage.png

Symbol.toPrimitive

该知名符号会影响类型转换的结果

  1. const obj ={
  2. a:123,
  3. b:1
  4. }
  5. obj[Symbol.toPrimitive] = function(){
  6. return 2
  7. }
  8. console.log(obj * 222)

image.png
正常情况下
image.png
之所以是NaN是因为obj是个一个对象,会隐士类型转换为number 字符串转为number是NaN NaN * number 还会NaN

Symbol.toStringTag

该知名符号会影响 Object.prototype.toString 的返回值

  1. class Person {
  2. [Symbol.toStringTag] = "Person"
  3. }
  4. const p = new Person();
  5. const arr = [32424, 45654, 32]
  6. console.log(Object.prototype.toString.apply(p));
  7. console.log(Object.prototype.toString.apply(arr))

image.png