鍍金池/ 問(wèn)答/網(wǎng)絡(luò)安全  HTML/ react中引用的外部變量為什么在調(diào)試環(huán)境中看不到值?

react中引用的外部變量為什么在調(diào)試環(huán)境中看不到值?

場(chǎng)景

比如我定義一個(gè)常量文件,在另一個(gè)組件引用,明明常量是管用的,但是在調(diào)試工具中,看引入的常量值卻是undefined,為什么?

code

//constant.js
const Names={man:'zhangsan',woman:'xiaoli'}

export {Names}



//MyComponent.js
import {Names} from './constant.js'

...省略代碼

componentDidMount(){
debugger;
}

圖片描述

操作

打開(kāi)調(diào)試工具,當(dāng)進(jìn)入didMount的時(shí)候,可以用鼠標(biāo)看下Names的值,是undefined,提示未定義。
但是在代碼中使用確實(shí)是沒(méi)問(wèn)題的。

不僅僅是常量,所有import的都看不到值。

回答
編輯回答
默念

import {Names} from './constant.js'
步一、進(jìn)行import的時(shí)候,webpack調(diào)用__webpack_require__方法,將模塊(constant)緩存放入installedModules中 如圖
圖片描述

步二、模塊constant.js內(nèi)部會(huì)被編譯成如下 圖片描述

步三,在index.js 中 將導(dǎo)入進(jìn)來(lái)的模塊constant賦值給變量_constant,而Names只是_constant的一個(gè)屬性,所以Names不在作用域中,報(bào)出 referenceError錯(cuò)誤。

圖片描述

圖片描述

這個(gè)適用于所有import,將導(dǎo)入的模塊緩存,使用的時(shí)候賦值給新變量,導(dǎo)入的所有方法或者變量都變成了新變量的一個(gè)屬性,所以不存在作用域中

2018年7月6日 21:20
編輯回答
凹凸曼

這不很好嗎,當(dāng)需要時(shí)才分配內(nèi)存空間,節(jié)省空間。
試了一下,你加個(gè)console.log(Names),鼠標(biāo)下就可以看到了具體內(nèi)容了。

樓主問(wèn)題可以簡(jiǎn)化成:調(diào)試工具下,為何下面b的值為undefined。

; (function() {
    var b = 2; (function() {
        debugger
    })()

})()
2018年5月19日 06:51