{"id":1445,"date":"2024-11-18T12:17:45","date_gmt":"2024-11-18T04:17:45","guid":{"rendered":"https:\/\/www.haruhi.fans\/?p=1445"},"modified":"2024-11-18T12:20:32","modified_gmt":"2024-11-18T04:20:32","slug":"%e6%ad%8c%e8%af%8d","status":"publish","type":"post","link":"https:\/\/www.haruhi.fans\/?p=1445","title":{"rendered":"\u6b4c\u8bcd"},"content":{"rendered":"\n<p>\u5728\u542c\u5230\u6b4c\u8bcd\u65f6\u5019\uff0c\u603b\u662f\u5fcd\u4e0d\u4f4f\u8ddf\u7740\u8f7b\u8f7b\u54fc\u5531\u8d77\u6765\u3002\u4f46\u662f\uff0c\u5f53\u524d\u64ad\u653e\u5668\u53ea\u80fd\u591f\u5c55\u793a\u4e00\u884c\u8ba9\u6211\u5f88\u662f\u4e0d\u8212\u670d\uff0c\u5982\u679c\u60f3\u8981\u81ea\u5df1\u5531\u6216\u8005\u63d0\u524d\u6784\u601d\u6b4c\u8bcd\u53d8\u5f97\u975e\u5e38\u56f0\u96be\u3002\u6070\u597d\u60f3\u4e86\u89e3\u7f51\u7ad9\u8fd0\u8f6c\u673a\u5236\u548c\u9ad8\u7ea7\u529f\u80fd\uff0c\u5c31\u5b9e\u73b0\u4e86\u4e00\u4e2a\u8c03\u7528\u63a5\u53e3\u663e\u793a\u6b4c\u8bcd\u7684\u754c\u9762\uff0c\u4e5f\u5bf9\u8fd9\u4e2awordpress\u5e95\u5c42\u6709\u4e86\u4e00\u70b9\u4e86\u89e3\u3002<\/p>\n\n\n\n<h2 class=\"wp-block-heading\">\u5b9e\u73b0\u6b65\u9aa4<\/h2>\n\n\n\n<p>\u641c\u7d22\u540e\u53d1\u73b0\uff0cWordPress\u652f\u6301\u4e00\u79cd\u7b80\u7801\uff0c\u4f60\u53ef\u4ee5\u628a\u51fd\u6570\u6ce8\u518c\u4e0a\u53bb\uff0c\u7136\u540e\u8c03\u7528\u7b80\u7801\u4f7f\u7528\u3002\u5728\u5916\u89c2->\u4e3b\u9898\u6587\u4ef6\u7f16\u8f91\u5668\u91cc\u9762\uff0c\u6709\u4e2afuncitons.php\uff0c\u53ef\u4ee5\u5199\u597d\u51fd\u6570\u540e<code>add_shortcode<\/code>\u5bfc\u51fa\u3002<\/p>\n\n\n\n<p>\u6574\u4e86\u4e2a\u7b80\u5355\u7684\u7f51\u6613\u6b4c\u8bcd\u641c\u7d22\uff0c\u4f46\u662f\u8bdd\u8bf4\u5927\u90e8\u5206\u7cbe\u529b\u5176\u5b9e\u90fd\u5728\u8c03\u6574html\u6837\u5f0f\u4e0a\uff0c\u4ee5\u540e\u6709\u673a\u4f1a\u518d\u6765\u4fee\u6539\u5427<\/p>\n\n\n\n<pre class=\"wp-block-code\"><code>function fetch_lyrics_shortcode() {\n    return '\n    &lt;div id=\"search-container\">\n      &lt;input type=\"text\" id=\"song-search\" placeholder=\"\u8f93\u5165\u6b4c\u66f2\u540d...\" \/>\n      &lt;button onclick=\"searchSongs()\">\u641c\u7d22&lt;\/button>\n    &lt;\/div>\n    &lt;div id=\"dynamic-content\">&lt;\/div> &lt;!-- \u52a8\u6001\u751f\u6210\u7684\u5185\u5bb9\u5c06\u63d2\u5165\u8fd9\u91cc -->\n    &lt;script>\n      const apiKey = \"042648db043c49ce8b101721df4078af\";\n      const searchApiUrl = \"https:\/\/myhkw.cn\/open\/music\/search?key=\" + apiKey + \"&amp;type=wy&amp;page=1&amp;limit=10&amp;format=1\";\n      const lyricsApiUrl = \"https:\/\/myhkw.cn\/open\/music\/lrc?key=\" + apiKey + \"&amp;id=\";\n      const picApiUrl = \"https:\/\/myhkw.cn\/open\/music\/pic?key=\" + apiKey + \"&amp;id=\";\n\n      async function searchSongs() {\n        const query = document.getElementById(\"song-search\").value.trim();\n        if (!query) {\n          alert(\"\u8bf7\u8f93\u5165\u6b4c\u66f2\u540d\uff01\");\n          return;\n        }\n\n        const dynamicContent = document.getElementById(\"dynamic-content\");\n        dynamicContent.innerHTML = `\n          &lt;div id=\"search-results\" style=\"margin-top: 20px; height: 300px; overflow-y: auto; border: 1px solid #ddd; padding: 10px;\">\u641c\u7d22\u4e2d...&lt;\/div>\n          &lt;div id=\"lyrics-container\" style=\"margin-top: 20px;\">\u8bf7\u8f93\u5165\u6b4c\u66f2\u540d\u5e76\u70b9\u51fb\u641c\u7d22\u3002&lt;\/div>\n        `;\n\n        try {\n          const wyResults = await fetch(`${searchApiUrl}&amp;name=${encodeURIComponent(query)}`).then(res => res.json());\n          displaySearchResults(wyResults);\n        } catch (error) {\n          document.getElementById(\"search-results\").innerText = \"\u641c\u7d22\u5931\u8d25\uff1a\" + error.message;\n        }\n      }\n\n      async function displaySearchResults(wyResults) {\n        const container = document.getElementById(\"search-results\");\n        const songs = &#91;];\n\n        if (wyResults &amp;&amp; wyResults.code === 1 &amp;&amp; wyResults.data) {\n          songs.push(...wyResults.data.map(song => ({ ...song, platform: \"\u7f51\u6613\u4e91\" })));\n        }\n\n        if (songs.length === 0) {\n          container.innerHTML = \"\u672a\u627e\u5230\u76f8\u5173\u6b4c\u66f2\u3002\";\n          return;\n        }\n\n        const items = await Promise.all(\n          songs.map(async song => {\n            const picUrl = await fetchSongPic(song.id);\n            return `\n              &lt;div style=\"margin-bottom: 10px; padding: 10px; border: 1px solid #ddd;\">\n                &lt;img src=\"${picUrl}\" alt=\"${song.name}\" style=\"vertical-align: middle; margin-right: 10px; width: 50px; height: 50px;\">\n                &lt;strong>${song.name}&lt;\/strong> - ${Array.isArray(song.artist) ? song.artist.join(\", \") : song.artist} &lt;br>\n                \u4e13\u8f91: ${song.album || \"\u65e0\"} &lt;br>\n                &lt;button style=\"margin-top: 5px;\" onclick=\"fetchLyrics(${song.id})\">\u67e5\u770b\u6b4c\u8bcd&lt;\/button>\n              &lt;\/div>\n            `;\n          })\n        );\n\n        container.innerHTML = items.join(\"\");\n      }\n\n      async function fetchSongPic(songId) {\n        try {\n          const response = await fetch(`${picApiUrl}${songId}&amp;type=wy`);\n          if (!response.ok) {\n            throw new Error(\"\u8bf7\u6c42\u5931\u8d25\uff0c\u72b6\u6001\u7801: \" + response.status);\n          }\n          const data = await response.json();\n          return data &amp;&amp; data.code === 1 ? data.data : \"https:\/\/via.placeholder.com\/50\"; \/\/ \u5360\u4f4d\u56fe\n        } catch {\n          return \"https:\/\/via.placeholder.com\/50\"; \/\/ \u8bf7\u6c42\u5931\u8d25\u5907\u7528\u5360\u4f4d\u56fe\n        }\n      }\n\n      async function fetchLyrics(songId) {\n        const lyricsContainer = document.getElementById(\"lyrics-container\");\n        lyricsContainer.innerText = \"\u6b4c\u8bcd\u52a0\u8f7d\u4e2d...\";\n        try {\n          const response = await fetch(`${lyricsApiUrl}${songId}&amp;type=wy`);\n          if (!response.ok) {\n            throw new Error(\"\u8bf7\u6c42\u5931\u8d25\uff0c\u72b6\u6001\u7801: \" + response.status);\n          }\n          const data = await response.json();\n          displayLyrics(data);\n        } catch (error) {\n          lyricsContainer.innerText = \"\u52a0\u8f7d\u6b4c\u8bcd\u5931\u8d25\uff1a\" + error.message;\n        }\n      }\n\n      function displayLyrics(data) {\n        const container = document.getElementById(\"lyrics-container\");\n        if (data &amp;&amp; data.code === 1 &amp;&amp; data.data) {\n          const lyrics = data.data\n            .split(\"\\\\n\")\n            .filter(line => line.trim() !== \"\")\n            .join(\"&lt;br>\");\n          container.innerHTML = `&lt;pre>${lyrics}&lt;\/pre>`;\n        } else {\n          container.innerText = data &amp;&amp; data.msg ? data.msg : \"\u672a\u627e\u5230\u6b4c\u8bcd\u5185\u5bb9\u3002\";\n        }\n      }\n    &lt;\/script>\n    ';\n}\nadd_shortcode('fetch_lyrics', 'fetch_lyrics_shortcode');<\/code><\/pre>\n\n\n\n<p>\u63a5\u7740\uff0c\u56de\u5230\u6211\u4eec\u754c\u9762\uff0c\u8c03\u7528\u51fd\u6570<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/www.haruhi.fans\/wp-content\/uploads\/2024\/11\/image-29-1024x400.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"400\" data-original=\"https:\/\/www.haruhi.fans\/wp-content\/uploads\/2024\/11\/image-29-1024x400.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1448\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p>\u7136\u540e\u4e00\u5207\u5b8c\u6210<\/p>\n\n\n\n<figure class=\"wp-block-image size-large\"><div class='fancybox-wrapper lazyload-container-unload' data-fancybox='post-images' href='https:\/\/www.haruhi.fans\/wp-content\/uploads\/2024\/11\/image-28-1024x648.png'><img class=\"lazyload lazyload-style-1\" src=\"data:image\/svg+xml;base64,PCEtLUFyZ29uTG9hZGluZy0tPgo8c3ZnIHdpZHRoPSIxIiBoZWlnaHQ9IjEiIHhtbG5zPSJodHRwOi8vd3d3LnczLm9yZy8yMDAwL3N2ZyIgc3Ryb2tlPSIjZmZmZmZmMDAiPjxnPjwvZz4KPC9zdmc+\"  loading=\"lazy\" decoding=\"async\" width=\"1024\" height=\"648\" data-original=\"https:\/\/www.haruhi.fans\/wp-content\/uploads\/2024\/11\/image-28-1024x648.png\" src=\"data:image\/png;base64,iVBORw0KGgoAAAANSUhEUgAAAAEAAAABCAYAAAAfFcSJAAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsQAAA7EAZUrDhsAAAANSURBVBhXYzh8+PB\/AAffA0nNPuCLAAAAAElFTkSuQmCC\" alt=\"\" class=\"wp-image-1447\"  sizes=\"auto, (max-width: 1024px) 100vw, 1024px\" \/><\/div><\/figure>\n\n\n\n<p>\u3057\u304b\u3057\uff0c\u6211\u4e4b\u524d\u662f\u5c1d\u8bd5\u76f4\u63a5html\u6ce8\u5165\u7684\uff0c\u4f46\u662f\u5931\u8d25\u4e86\uff0c\u6ca1\u6709\u529e\u6cd5\u8bf7\u6c42\u3002\u53ef\u80fd\u662fWordPress\u5bf9\u4e8e\u754c\u9762JS\u6709\u6240\u9650\u5236\u5427\uff0c\u53ea\u80fd\u5728\u7279\u5b9a\u7684\u5730\u65b9\u8c03\u7528\u3002\u8fd9\u6837\u4e5f\u597d\uff0c\u6210\u719f\u7684\u6846\u67b6\u4e5f\u5c31\u5e94\u5f53\u5982\u6b64\u3002<\/p>\n","protected":false},"excerpt":{"rendered":"<p>\u5728\u542c\u5230\u6b4c\u8bcd\u65f6\u5019\uff0c\u603b\u662f\u5fcd\u4e0d\u4f4f\u8ddf\u7740\u8f7b\u8f7b\u54fc\u5531\u8d77\u6765\u3002\u4f46\u662f\uff0c\u5f53\u524d\u64ad\u653e\u5668\u53ea\u80fd\u591f\u5c55\u793a\u4e00\u884c\u8ba9\u6211\u5f88\u662f\u4e0d\u8212\u670d\uff0c\u5982\u679c\u60f3\u8981\u81ea\u5df1\u5531\u6216\u8005\u63d0 [&hellip;]<\/p>\n","protected":false},"author":1,"featured_media":1447,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"footnotes":""},"categories":[7],"tags":[],"class_list":["post-1445","post","type-post","status-publish","format-standard","has-post-thumbnail","hentry","category-tech"],"_links":{"self":[{"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/posts\/1445","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=%2Fwp%2Fv2%2Fcomments&post=1445"}],"version-history":[{"count":3,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/posts\/1445\/revisions"}],"predecessor-version":[{"id":1452,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/posts\/1445\/revisions\/1452"}],"wp:featuredmedia":[{"embeddable":true,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=\/wp\/v2\/media\/1447"}],"wp:attachment":[{"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=%2Fwp%2Fv2%2Fmedia&parent=1445"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=%2Fwp%2Fv2%2Fcategories&post=1445"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/www.haruhi.fans\/index.php?rest_route=%2Fwp%2Fv2%2Ftags&post=1445"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}