Imr*_*anR 3 javascript ecmascript-6 reactjs fetch-api
我对 React 还很陌生。我正在从 API 获取数据,并且在检查控制台日志时可以看到数据。但是,我不知道如何使用 map() 创建一个新数组,然后选项元素可以使用该数组来显示货币代码。
目前它填充下拉列表,但选项元素都是空的,结果显示为 NaN。
下面是我获取数据的代码示例。
state = {
currencies: [],
base: "USD", //default value
amount: "",
convertTo: "EUR",
result: ""
};
componentDidMount() {
fetch("https://api.exchangeratesapi.io/latest")
.then(response => {
return response.json();
})
.then(data => {
let currenciesFromApi = Object.keys(data.rates);
console.log(currenciesFromApi);
this.setState({
currencies: currenciesFromApi
});
})
.catch(error => {
console.log(error);
});
}
Run Code Online (Sandbox Code Playgroud)
预期结果:下拉列表将填充来自 API 的货币代码(例如英镑、欧元、美元)和值以显示汇率而不是 NaN。
实际结果:下拉列表是空的,选择其中任何一个也会返回 Nan。
我检查了源代码,似乎货币数组只包含字符串值。因此,当您通过它们进行映射以呈现选项时,只需将变量直接用作字符串即可。
{this.state.currencies.map(currency => (
<option key={currency} value={currency}>
{currency}
</option>
))}
Run Code Online (Sandbox Code Playgroud)
见:https : //codesandbox.io/s/hu8cb
| 归档时间: |
|
| 查看次数: |
9907 次 |
| 最近记录: |