Как я могу отсортировать RSS-канал через .ISODate и сохранить связанное содержимое канала (заголовок и ссылка)?

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». Я обновил код, чтобы сделать его понятным.