Tiven

Tiven

博观而约取,厚积而薄发

天问的个人网站(天问博客),专注于Node.js、Vue.js、React、Vite、Npm、Nginx等大前端技术。不断学习新技术,记录日常开发问题,持续分享coding,极客开源,共同进步。生命不息,奋斗不止... [ Hexo Blog ]

JS中对象和属性的连续赋值


前端面试中的疑难杂症——JS 中对象和属性的连续赋值问题。

JavaScript

一、经典面试题

let a = {n:1}
let b = a
a.x = a = {n:2}

console.log(a.x)
console.log(b.x)

二、关键考点

  1. 值类型 vs 引用类型
// 值类型,赋值后相互独立
let a = 100
let b = a

// 引用类型,赋值后指向堆中的引用
let c = {n:1}
let d = c
  1. 连续赋值,倒序执行
let a1, a2
a1 = a2 = 10

// 相当于
a2 = 10
a1 = a2
  1. a.x赋值(=) 的优先级高

值类型赋值:

let a = {}
a.x = 100

// 拆解为
// 1. a.x = undefined // 初始化 a.x 属性
// 2. a.x = 100 // 为 x 属性赋值

引用类型赋值:

let a = {n:1}
let b = a
a.x = a = {n:2}

// a.x = a = {n:2} 拆解为
// 1. a = b = {n:1, x: undefined}
// 2. a = {n:2}
// 3. a.x = {n:2}
// 4. b = {n:1, x: {n:2}}

堆栈示例图

三、输出

console.log(a.x) // undefined
console.log(b.x) // {n:2}

欢迎访问:天问博客