当前位置:   article > 正文

ES6数组判断以及原始值转换

ES6数组判断以及原始值转换

一. 数组判断

  1. 情况一
const target = {}

function isArray(target) {
    return Object.prototype.toString.call(target) === "[object Array]"
}
console.log(isArray(target)) // false
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
const target = {
    [Symbol.toStringTag]: "Array",
}

function isArray(target) {
    return Object.prototype.toString.call(target) === "[object Array]"
}
console.log(isArray(target)) // true
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8

  1. 情况二
const target = {}

function isArray(target) {
    return target instanceof Array
}

console.log(isArray(target)) // false
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
const target = {}
Object.setPrototypeOf(target, Array.prototype)
function isArray(target) {
    return target instanceof Array
}

console.log(isArray(target)) // true
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7

使用ES6

const target = {
    [Symbol.toStringTag]: "Array",
}

Object.setPrototypeOf(target, Array.prototype)

function isArray(target) {
    return Array.isArray(target)
}

console.log(isArray(target)) // false
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

二. 原始值转换

  1. 情况一
const target = {}
console.log(target.toString()) // [object Object]
console.log(target + 1) // [object Object]1
  • 1
  • 2
  • 3
  1. 情况二
const target = {
    toString() { return 1 },
}
console.log(target.toString()) // 1
console.log(target + 1) // 2
  • 1
  • 2
  • 3
  • 4
  • 5
  1. 情况三
const target = {
    toString() { return 1 },
    valueOf() {
        return 2
    },
}
console.log(target.toString()) // 1
console.log(target + 1) // 3
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  1. 情况四 参考mdn
const target = {
    toString() { return 1 },
    valueOf() {
        return 2
    },
    [Symbol.toPrimitive](hint) {
        return 3
    },
}
console.log(target.toString()) // 1
console.log(target + 1) // 4
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11

原始值强制转换优先权重:[Symbol.toPrimitive] > valueOf > toString

声明:本文内容由网友自发贡献,转载请注明出处:【wpsshop博客】
推荐阅读
相关标签
  

闽ICP备14008679号