gpt4 book ai didi

javascript - 如何将我的 API 调用的图像结果作为背景图像附加到我的应用程序?

转载 作者:太空宇宙 更新时间:2023-11-04 06:11:00 25 4
gpt4 key购买 nike

关于我正在尝试做的事情的背景.. 用户输入城市和背景更改为该城市的图像,该图像是通过对 Pixabay API 的 API 调用获取的。我将结果保存为变量“背景”,但我不知道如何将它附加到页面背景。 “const background”变量本身呈现图像 URL。这意味着当我使用 console.log(background) 时,我得到了我想要应用到整个页面的背景图片的 URL。

import React, { Component } from "react";
import Title from "./Title.js";
import Form from "./Form.js";
import Weather from "./Weather.js";
import axios from "axios";

// import logo from "./logo.svg";
import "./App.css";

const API_KEY = "b6907d289e10d714a6e88b30761fae22";
// const API_ID = "12653279-f2ae53f8bfb342d39b6cbf92b";

class App extends Component {
// the initial state of the application is set below, will change upon submit of button
state = {
temperature: undefined,
city: undefined,
description: undefined,
error: undefined,
searchText: "",
apiUrl: "https://pixabay.com/api",
apiKey: "12653279-f2ae53f8bfb342d39b6cbf92b",
images: []
};
getweatherData = async e => {
// arrow function used as an alternative to constructor to bind data and use "this" to still be bound to component
// async returns a promsise to be settled
e.preventDefault();
// e argument passed in the async function is now used to prevent refresh default action
const city = e.target.elements.city.value;
// a way that we can make the city value dynamic within the api url in the api call
const api_call = await fetch(
// await key word pauses the function until data is recieved from api call
`https://openweathermap.org/data/2.5/weather?q=${city}&appid=${API_KEY}`
);
const data = await api_call.json();
// above, the data recieved from the API is converted to json readable format
console.log(data);
if (data.cod === 404) {
throw Error(data.message);
} else {
this.setState({
temperature: data.main.temp.toFixed(0),
city: data.sys.city,
country: data.sys.country,
description: data.weather[0].description,
error: "undefined"
});
}
axios
.get(
`${this.state.apiUrl}/?key=${
this.state.apiKey
}&q=${city}&image_type=photo&per_page="1"
}&safesearch=true&editorschoice= true`
)
.then(res => {
this.setState({ images: res.data.hits });
const background = res.data.hits[1];
console.log(background);
});
};

render() {
return (
<div className="container">
<Title />
{/* setting up a prop to the getweatherData value so we can have access to it in the form.js */}
<Form getweatherData={this.getweatherData} />
{/* defining props so they can be accessed in the weather.js */}
<Weather
temperature={this.state.temperature}
city={this.state.city}
country={this.state.country}
description={this.state.description}
error={this.state.error}
/>
</div>
);
}
}

export default App;

表格。 js

import React, { Component } from "react";

class Form extends Component {
render() {
return (
// a react attribute onSubmit to call in our prop
<form onSubmit={this.props.getweatherData}>
<input type="text" name="city" placeholder="City..." />
{/* <input type="text" name="country" placeholder="Country..." /> */}
<button>Get Weather</button>
</form>
);
}
}

export default Form;

最佳答案

将背景图像设置为状态,然后在您希望显示它的任何元素上使用内联样式。像这样。

...
const background = res.data.hits[1];
this.setState({ background })
...
return (
<div className="container" style={{ this.state.background ? { background: this.state.background } : {} }}>
...

关于javascript - 如何将我的 API 调用的图像结果作为背景图像附加到我的应用程序?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56408948/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com