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

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

場景

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

code

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

export {Names}



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

...省略代碼

componentDidMount(){
debugger;
}

圖片描述

操作

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

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

回答
編輯回答
默念

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

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

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

圖片描述

圖片描述

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

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

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

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

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

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