J'ai un problème avec async
/await
. Voici mon code:
import axios from 'axios'
export default async function getRequestedData (requestAddress, params) {
return await axios.get(requestAddress, {params: params})
}
Mais au lieu du résultat, il renvoie une promesse complète. Les données sont donc fortement imbriquées dans une promesse:
Comme Ha Ja l'a dit, je pense que vous devez toujours résoudre la promesse. Si vous retournez simplement l'attente, vous obtiendrez une promesse.
const fs = require ('fs')
function getText () {
return new Promise( (resolve, reject) => {
fs.readFile('./foo.txt', 'utf8', (err, data) => {
if (err) {
reject(err)
}
resolve(data)
})
})
}
async function output () {
try {
let result = await getText()
console.log("inside try: ", result)
return result
}
catch (err){
console.log(err)
}
}
console.log("outside: ", output())
output().then( result => console.log("after then: ", result))
// outside: Promise { <pending> }
// inside try: foo text
// inside try: foo text
// after then: foo text
Vous devez renvoyer les données:
const response = await axios.get(requestAddress, {params: params})
return response.data;
En composant React, vous pouvez faire avec cette astuce:
function InitProduct() {
// Get your product from database
var productId = 'abc';
axios.get('/api/products/' + productId).then(response => {
$('.' + productId).text(response.data.ProductTitle);
});
return (<div className={productId}></div>)
}
export class TestNow extends Component {
render() {
return (
<div>
{InitProduct()}
</div>
)
}
}