リアルタイムRSSトレンド.html

<!DOCTYPE html>
<html lang="ja">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>リアルタイムRSSトレンド</title>
    <style>
        body { font-family: Arial, sans-serif; background-color: #f4f4f4; margin: 0; padding: 0; }
        h1 { text-align: center; padding: 20px; background: #333; color: white; }
        #rss-feed { max-width: 800px; margin: 20px auto; padding: 20px; background: white; box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); }
        .article { border-bottom: 1px solid #ccc; padding: 15px; display: flex; flex-direction: column; }
        .article:last-child { border-bottom: none; }
        .article a { text-decoration: none; color: #333; font-weight: bold; font-size: 16px; }
        .article a:hover { color: #007bff; }
        .article p { margin: 5px 0; color: #666; font-size: 14px; }
        .loader { text-align: center; font-size: 18px; color: #666; }
        .refresh-btn { display: block; width: 200px; margin: 20px auto; padding: 10px; background: #007bff; color: white; text-align: center; cursor: pointer; border-radius: 5px; }
        .refresh-btn:hover { background: #0056b3; }
        .error { text-align: center; color: red; font-weight: bold; }
    </style>
</head>
<body>
    <h1>リアルタイムRSSトレンド</h1>
    <div id="rss-feed" class="loader">読み込み中...</div>
    <div class="refresh-btn" onclick="loadRSS()">最新の情報を取得</div>
    <div id="error-message" class="error"></div>
    
    <script>
        async function fetchRSS(url) {
            try {
                const response = await fetch(`https://api.rss2json.com/v1/api.json?rss_url=${encodeURIComponent(url)}`);
                if (!response.ok) throw new Error("RSS取得に失敗しました");
                const data = await response.json();
                return data.items || [];
            } catch (error) {
                console.error("RSSの取得に失敗しました", error);
                return [];
            }
        }

        async function loadRSS() {
            const feedElement = document.getElementById("rss-feed");
            const errorElement = document.getElementById("error-message");
            feedElement.innerHTML = "読み込み中...";
            errorElement.innerHTML = "";
            
            const rssUrls = [
                "https://news.google.com/rss?hl=ja&gl=JP&ceid=JP:ja",
                "https://rss.itmedia.co.jp/rss/2.0/news_bursts.xml",
                "https://www3.nhk.or.jp/rss/news/cat0.xml"
            ];
            
            let allArticles = [];
            for (const url of rssUrls) {
                const articles = await fetchRSS(url);
                allArticles = allArticles.concat(articles);
            }
            
            if (allArticles.length === 0) {
                feedElement.innerHTML = "";
                errorElement.innerHTML = "記事が取得できませんでした。";
                return;
            }
            
            allArticles.sort((a, b) => new Date(b.pubDate) - new Date(a.pubDate));
            feedElement.innerHTML = "";
            
            allArticles.forEach(article => {
                const articleElement = document.createElement("div");
                articleElement.classList.add("article");
                articleElement.innerHTML = `
                    <a href="${article.link}" target="_blank">${article.title}</a>
                    <p>公開日時: ${new Date(article.pubDate).toLocaleString()}</p>
                `;
                feedElement.appendChild(articleElement);
            });
        }
        
        document.addEventListener("DOMContentLoaded", loadRSS);
        setInterval(loadRSS, 300000); // 5分ごとに自動更新
    </script>
</body>
</html>

投稿者: chosuke

趣味はゲームやアニメや漫画などです

コメントを残す

メールアドレスが公開されることはありません。 が付いている欄は必須項目です