作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在尝试将一个对象导入另一个 JS 文件,但我不断收到此错误,未捕获的 ReferenceError:在初始化之前无法访问“股票”。我已经申报了库存,并且我已经正确导入了它,所以我看不出我做错了什么。任何帮助深表感谢。谢谢。
在股票文件中:
export const stocks = {
megaCorp: {
name: 'Mega Corporation',
value: decideStockValue(),
portIn: 0,
document: "mega"
},
lunaBake: {
name: "Luna Baking",
value: decideStockValue(),
portIn: 1,
document: "luna"
},
}
import { stocks } from "./stocks.js";
export let user = {
money: 2000,
portfolio: [0, 0, 0, 0]
}
function getValue () {
let value = user.money;
let cannon = stocks.cannonRock.value * user.portfolio[0];
let alpha = stocks.alphaComp.value * user.portfolio[1];
let luna = stocks.lunaBake.value * user.portfolio[2];
let mega = stocks.megaCorp.value * user.portfolio[3];
value += cannon;
value += alpha;
value += luna;
value += mega;
return value;
}
user.value = getValue();
最佳答案
再次查看代码,它似乎在语法上很好,所以这不是一个答案,但我宁愿分享一段代码来看看它的行为方式。
您分享的错误 Uncaught ReferenceError: Cannot access 'variable_name' before initialization
在初始化之前访问词法变量时会抛出它(所谓的时间死区错误),但是在您共享的代码中没有任何东西应该抛出这个错误。
例如这段代码会抛出这个错误
const x = 3
function a(){
console.log(x)
const x = 5;
}
a()
import { stocks } from "./stocks.js";
const getValue = (stocks, money, portfolio) => {
let value = money;
let cannon = stocks.cannonRock.value * portfolio[0];
let alpha = stocks.alphaComp.value * portfolio[1];
let luna = stocks.lunaBake.value * portfolio[2];
let mega = stocks.megaCorp.value * portfolio[3];
value += cannon;
value += alpha;
value += luna;
value += mega;
return value;
};
const money = 2000;
const portfolio = [0, 0, 0, 0];
export const user = {
money,
portfolio,
value: getValue(stocks, money, portfolio),
};
关于javascript - Uncaught ReferenceError : Cannot access 'stocks' before initialization,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/62202164/
我是一名优秀的程序员,十分优秀!