在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

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

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

場景

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

code

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

export {Names}



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

...省略代碼

componentDidMount(){
debugger;
}

圖片描述

操作

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

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

回答
編輯回答
默念

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

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

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

圖片描述

圖片描述

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

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

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

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

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

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