前端进阶之旅前端进阶之旅
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
      • 第一补: JS类型基础
        • 1. ‘1’.toString()为什么可以调用,1.toString()却不行?
        • 2. 为什么可以使用new Number却不能使用new Symbol?
      • 第二补:JS类型检测
        • 1. instanceof能否判断基本数据类型?
        • 2. instanceof的查找路线?
        • 3. isPropertypeOf()有什么作用?
        • 4. Object.is()和===的区别?
      • 第三补:toString()方法的妙用
        • 1. toString()存在于哪里?
        • 2. 谁可以调用toString()?
        • 3. 如何用toString()判断某个数据的具体类型?
        • 4. toString.call()与typeof的区别?
        • 5. 不同类型的数据调用toString()会怎么样?
          • 5.1 基本数据类型调用toString
          • 5.2 引用类型调用toString
        • 6. 了解Symbol.toStringTag吗?
      • 第四补:JS类型转换
        • 1. 说一下valueOf()的基本用法
        • 2. ToPrimitive的具体转换流程?
          • 2.1 对象转字符串
          • 2.2 对象转数字
        • 3. 数组转换为字符串为什么会用","连接?
        • 4. 知道Symbol.toPrimitive吗?它有什么用?
        • 5. ==在进行比较时的类型转换?
        • 6. 几种一元运算符的类型转换?
        • 7. 你会几种让if(a == 1 && a == 2 && a == 3)条件成立的办法?
        • 8. 让if (a === 1 && a === 2 && a === 3)条件成立?
        • 9. 控制台输入{}+[]会怎样?
      • 第五补:八种JS继承
        • 1. 原型链继承
        • 2. 构造继承
        • 3. 组合继承
        • 4. 寄生组合继承
        • 5. 原型式继承
        • 6. 寄生式继承
        • 7. 混入方式继承
        • 8. class中的继承
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合

完整面试题地址:
作者:程序员poetry
扫码关注作者公众号:「前端进阶之旅」 每天分享技术干货
前端进阶之旅公众号二维码

# 第一补: JS类型基础

# 1. ‘1’.toString()为什么可以调用,1.toString()却不行?

我们知道如果在代码中使用:

'1'.toString()
// 或者是
true.toString()
@前端进阶之旅: 代码已经复制到剪贴板

都是可以正常调用的,这是因为toString它是Object.prototype上的方法,任何能访问到Object原型的元素都可以调用它。

而在此处,对于'1'.toString()相当于是做了一层转换,将其转为了一个"对象",这样就可以调用toString()方法了。

也就是这样:

var s = new Object('1');
s.toString();
s = null;
@前端进阶之旅: 代码已经复制到剪贴板
  • 创建Object实例,将s变为了String{"1"}对象
  • 调用Object.prototype上的实例方法toString()
  • 用完之后立即销毁这个实例

这一部分三元分析的已经挺多了,我主要是想补充一下1.toString()为什么就不行。

当我们在代码中试图使用1.toString(),发现编辑器已经报错不允许我们这样做了。

最开始会有这么奇怪的想法是因为我们都忽视了一件事,那就是.它也是属于数字里的一部分啊 😂。

比如1.2、1.3。所以当你想要使用1.toString()的时候,JavaScript的解释器会把它作为数字的一部分,这样就相当于(1.)toString了,很显然这是一段错误的代码。

既然这样的话,如果我还给代码一个.是不是就可以了,于是我尝试了一下:

console.log(1.1.toString())
@前端进阶之旅: 代码已经复制到剪贴板

发现它竟然能正常打印出来:

"1.1"
@前端进阶之旅: 代码已经复制到剪贴板

这也就再次证明了1.toString()会将.归给1所属,而不是归给toString()。

当然如果你用的一个变量来承载这个数字的话也是可以的:

var num = 1;
console.log(num.toString()) // "1"

// 或者
fe
基础篇
进阶篇
高频篇
精选篇
手写篇
原理篇
面经篇
自检篇
每日一题
  • 综合
    • 综合题型
    • 其他问题
    • 设计模式
    • 思维导图
    • 学习路线
  • 前端基础
    • HTTP
    • 浏览器
    • 计算机基础
  • 进阶学习
    • NPM工作流
    • Docker
    • Canvas
    • Node学习指南
    • 前端综合文章
  • 其他
    • Handbook
    • 职场话题
    • CSS可视化
小程序题库
公众号动态
博客动态
开发者导航
  • JavaScript Part 1

    • Ajax总结篇
    • Canvas 绘制八大行星
    • Canvas 绘制动画时钟
    • Canvas 绘制粒子动画背景
    • DOM编程之API学习总结篇
    • JS 中的 call、apply、bind 方法
    • JS 中的事件绑定、事件监听、事件委托
    • JS常用的内置函数整理
    • JS继承的几种方法总结
    • JS计算字符串所占字节数
    • JavaScript-DOM事件
    • JavaScript事件机制
    • JavaScript代码片段100个
    • JavaScript作用域分析总结
    • JavaScript原型链回顾
    • JavaScript原生数组及高阶函数
    • JavaScript及jQuery中的各种宽高属性图解
    • JavaScript启示录阅读笔录
    • JavaScript对象
    • JavaScript工程项目的一系列最佳实践
    • JavaScript常用API合集
    • JavaScript常用的代码片段
    • JavaScript数组、字符串、对象常用方法
    • JavaScript数组方法总结篇
    • JavaScript深浅拷贝
    • JavaScript继承的几种方式
    • JavaScript词法分析和作用域闭包
    • JavaScript运动框架之速度时间版本
    • JavaScript运行机制Event Loop
    • JavaScript防抖节流原理
    • Javascript中的复制粘贴功能
    • Javascript常用方法函数收集
    • Javascript数组详解
    • OOP之原型与原型链
    • OOP之类与对象
    • OOP之面向对象
    • Object.defineProperty详解
    • V8源码浅析JS数组常见方法
    • arguments详解
    • await 在 forEach 中不生效解决方案
    • iframe+表单跨域提交POST请求
    • javascript 下常用的字符串操作
    • javascript常用积累
    • javascript笔记总结篇
    • parsetInt parsetFloat与eval isNaN用法
    • 业务中处理数据结构常用的JS方法
    • 作用域
    • 你真的掌握变量和类型了吗
    • 前后端分离之数据Mock
    • 原型与原型链
    • 原生JS与jQuery操作DOM对比
    • 原生JS补给(上)
      • 第一补: JS类型基础
        • 1. ‘1’.toString()为什么可以调用,1.toString()却不行?
        • 2. 为什么可以使用new Number却不能使用new Symbol?
      • 第二补:JS类型检测
        • 1. instanceof能否判断基本数据类型?
        • 2. instanceof的查找路线?
        • 3. isPropertypeOf()有什么作用?
        • 4. Object.is()和===的区别?
      • 第三补:toString()方法的妙用
        • 1. toString()存在于哪里?
        • 2. 谁可以调用toString()?
        • 3. 如何用toString()判断某个数据的具体类型?
        • 4. toString.call()与typeof的区别?
        • 5. 不同类型的数据调用toString()会怎么样?
          • 5.1 基本数据类型调用toString
          • 5.2 引用类型调用toString
        • 6. 了解Symbol.toStringTag吗?
      • 第四补:JS类型转换
        • 1. 说一下valueOf()的基本用法
        • 2. ToPrimitive的具体转换流程?
          • 2.1 对象转字符串
          • 2.2 对象转数字
        • 3. 数组转换为字符串为什么会用","连接?
        • 4. 知道Symbol.toPrimitive吗?它有什么用?
        • 5. ==在进行比较时的类型转换?
        • 6. 几种一元运算符的类型转换?
        • 7. 你会几种让if(a == 1 && a == 2 && a == 3)条件成立的办法?
        • 8. 让if (a === 1 && a === 2 && a === 3)条件成立?
        • 9. 控制台输入{}+[]会怎样?
      • 第五补:八种JS继承
        • 1. 原型链继承
        • 2. 构造继承
        • 3. 组合继承
        • 4. 寄生组合继承
        • 5. 原型式继承
        • 6. 寄生式继承
        • 7. 混入方式继承
        • 8. class中的继承
    • 如何写出一个惊艳面试官的深拷贝
    • 带你填一些JS容易出错的坑
    • 彻底弄懂 JavaScript 执行机制
    • 执行上下文 执行栈
    • 梳理常用的正则表达式
    • 正则回顾总结
    • 正则基础知识
    • 正则完整篇
    • 正则表达式
    • 浅析JSON stringify
    • 浅析Promise原理
    • 浅谈JavaScript中的异步处理
    • 浅谈闭包
    • 深拷贝 vs 浅拷贝
    • 编写可维护的JavaScript
    • 聊一聊typeof instanceof 实现原理.
    • 聊一聊闭包
    • 高阶函数map reduce filter
  • JavaScript Part 2

  • CSS

  • HTML

  • Jquery

  • ES6

  • 小程序

  • Vue

  • React

  • 深入React

  • React Native

  • NodeJS

  • Angular

  • TypeScript

  • Webpack

  • 浏览器

  • 移动端

  • 前端工程化

  • Electron

  • HTTP

  • Nginx

  • Linux

  • 数据结构与算法

  • LeetCode算法题

  • 综合