es6模块报错Uncaught ReferenceError: Cannot access '.' before initialization

情况描述

项目是默认使用webpack编译采用es6模块处理方案
出现了以下错误错误详情
以下是我写的测试类
A.ts

import {
   B} from "./b.js";

export class A {
   
    static getInstance() {
   
        if (!this._instance) {
   
            this._instance = new A();
        }
        return this._instance;
    }
    flush() {
   
        console.log("----------------flush-------------------");
    }
    a() {
   
        console.log("----------------flush-------------------"
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在JavaScript中,当我们使用一个变量或对象之前没有对它进行初始化时,就会出现"cannot access before initialization"的错误。 这个错误通常发生在以下几种情况下: 1. 变量声明但没有赋值:当我们声明一个变量但没有赋予初始值时,变量的值将是undefined。如果我们在赋值之前尝试访问这个变量,就会出现"cannot access before initialization"的错误。 例如: ``` let x; console.log(x); // 无法访问变量x的值,因为它没有被初始化 ``` 2. 块级作用域中的变量:在ES6之前,JavaScript只有函数作用域,变量在声明它们的函数或全局作用域中可见。但是,在ES6中引入了块级作用域,例如使用let或const声明的变量。 例如: ``` if (true) { let y = 10; } console.log(y); // 无法访问变量y的值,因为它在块级作用域之外 ``` 3. 访问尚未声明的变量:如果我们在访问一个尚未声明的变量之前尝试访问它,也会出现"cannot access before initialization"的错误。 例如: ``` console.log(z); // 无法访问尚未声明的变量z let z = 20; ``` 为了避免这个错误,我们可以在使用变量之前进行初始化赋值。可以使用默认值,或在声明变量时立即赋值。 例如: ``` let x = 0; console.log(x); // 可以访问并打印变量x的值 let y = 10; if (true) { y = 20; } console.log(y); // 可以访问并打印变量y的值 let z; console.log(z); // 可以访问变量z的值,结果为undefined z = 20; ```

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值