【发布时间】:2019-03-03 21:19:22
【问题描述】:
我正在制作一个 React 应用程序,它可以按书名搜索一本书并返回结果。
它大部分工作正常,但是对于搜索的某些标题(例如“hello”)它无法获得结果,因为缺少参数。
特别是,“金额”值丢失了,即使我在获取 api 时添加了filter=paid-ebooks 参数,它也可以获得非出售的电子书。使用projection=full 也无济于事。
例如,当我用
调用 api 时https://www.googleapis.com/books/v1/volumes?printType=books&filter=paid-ebooks&key=${APIKEY}
并在 reactjs 中使用 books 数组中获取的数据:
this.props.books.map((book, index) => {
return (
<CardItem
key={index}
title={book.volumeInfo.title}
authors={book.volumeInfo.authors ?
book.volumeInfo.authors.join(', ') :
"Not provided"}
price={book.saleInfo.listPrice.amount}
publisher={book.volumeInfo.publisher}
addToCart={() =>
this.props.addItem(this.props.books[index])}
/>
)
})
它得到的一个结果是这样的:
"saleInfo": {
"country": "TR",
"saleability": "NOT_FOR_SALE",
"isEbook": false
}
虽然应该是这样,但预期的是:
"saleInfo": {
"country": "TR",
"saleability": "FOR_SALE",
"isEbook": true,
"listPrice": {
"amount": 17.23,
"currencyCode": "TRY"
}
并尝试使用此 api 答案进行搜索会引发错误:
TypeError: Cannot read property 'amount' of undefined
price={book.saleInfo.listPrice.amount}
正如您在反应代码的authors 中看到的那样,这个问题也与作者参数有关,我已经绕过了,如代码中所示。但我不能对amount 做同样的事情。这是 Google Books API 中的一个已知错误,还是有办法防止这种情况发生?我不明白为什么即使使用filter=paid-ebooks 参数,它仍然会退回我不出售的电子书。
【问题讨论】:
标签: json reactjs google-api google-books