javascript #node.js #reactjs #rss #rss-reader
#javascript #node.js #reactjs #RSS-канал #rss-reader
Вопрос:
Я хотел бы отсортировать RSS-канал по самому последнему элементу и сохранить соответствие заголовка элемента соответствующей ссылке. Вот как я анализирую и отображаю канал. Свойство, которое, как я думал, было бы лучшим для этого, — .ISODate, я не уверен в том, как выполнить этот процесс.
Я заставил его работать, просто поместив: item.ISODate item.title в массив и отсортировав его, и проделав то же самое для массива для item.ISODate item.link . Однако это было быстрое решение, и оно не всегда работает с большими каналами.
function MarinersFeed() {
const [disable, setDisable] = React.useState(false);
const [completeFeed, setCompletedFeed] = React.useState([]);
const [feedTitle, setFeedTitle] = React.useState([]);
const [feedLink, setFeedLink] = React.useState([]);
React.useEffect(async () => {
let Parser = require('rss-parser');
let parser = new Parser();
const tFeed = [];
const tFeedTitle = [];
const tFeedLink = []
let feed = await parser.parseURL('https:*******.herokuapp.com/https://www.mlb.com/mariners/feeds/news/rss.xml');
feed.items.forEach(item => {
//sort by using item.isoDate, keep item.title and item.link connected
tFeed.push(item.title);
tFeedLink.push( item.link);
});
setCompletedFeed(tFeed);
//setFeedTitle(tFeedTitle);
setFeedLink(tFeedLink);
}, []);
const renderData = () => {
return completeFeed.map((f, index) => {
const title = feedTitle[index];
const link = feedLink[index]
const fullFeed = completeFeed[index]
return <div key={index} >
<h3>{fullFeed}
<Button onClick={(e) => {
e.preventDefault();
console.log(link)
window.open(link, "_blank")
}}></Button></h3>
</div>
})
}
return(
<>
{renderData()}
</>
)
}
export default MarinersFeed;
Ответ №1:
Вы можете использовать метод сортировки массива, например
const RssParser = require('rss-parser');
async function fetchRss({ url, sort = false, sortOrder = 'desc' } = {}) {
const rssParser = new RssParser();
const feed = await rssParser.parseURL(url);
if (sort) {
feed.items.sort((a, b) => {
return sortOrder === 'asc'
? new Date(a.isoDate) - new Date(b.isoDate) // Oldest first
: new Date(b.isoDate) - new Date(a.isoDate); // Newest first
});
}
return feed;
}
async function main() {
const output = await fetchRss({ url: 'https://www.mlb.com/mariners/feeds/news/rss.xml', sort: true });
console.log(output);
}
main();
Вывод:
{
items: [
{
creator: 'Jim Callis, Sam Dykstra and Jonathan Mayo',
title: '30 AFL sleeper prospects -- 1 for each org.',
link: 'https://www.mlb.com/mariners/news/sleeper-prospects-in-arizona-fall-league-2021',
pubDate: 'Fri, 15 Oct 2021 01:46:57 GMT',
'dc:creator': 'Jim Callis, Sam Dykstra and Jonathan Mayo',
guid: 'https://www.mlb.com/mariners/news/sleeper-prospects-in-arizona-fall-league-2021',
isoDate: '2021-10-15T01:46:57.000Z'
},
{
creator: 'Daniel Kramer',
title: 'J-Rod launches his own YouTube channel',
link: 'https://www.mlb.com/mariners/news/julio-rodriguez-mariners-top-prospect-launching-youtube-channel',
pubDate: 'Thu, 14 Oct 2021 14:31:30 GMT',
'dc:creator': 'Daniel Kramer',
guid: 'https://www.mlb.com/mariners/news/julio-rodriguez-mariners-top-prospect-launching-youtube-channel',
isoDate: '2021-10-14T14:31:30.000Z'
},
...
Комментарии:
1. У меня проблемы с отображением выходных данных. Как мне это сделать?
2. Когда я запускаю этот код, я получаю следующую ошибку: «Неожиданное зарезервированное слово ‘await'» — почему это?
3. @corbinc1998 это потому, что «await» должен вызываться в контексте функции «async». Я обновил код, чтобы сделать его понятным.