您需要先安装一个扩展,例如 篡改猴、Greasemonkey 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 暴力猴,之后才能安装此脚本。
您需要先安装一个扩展,例如 篡改猴 或 Userscripts ,之后才能安装此脚本。
您需要先安装一款用户脚本管理器扩展,例如 Tampermonkey,才能安装此脚本。
您需要先安装用户脚本管理器扩展后才能安装此脚本。
该脚本能够放大Steam平台的大部分界面元素,提升阅读和操作体验;在CSGO社区市场详情页显示Buff平台的价格对比并提供跳转链接,方便用户快速查看和购买;同时在游戏详情页添加快捷跳转按钮,连接到小黑盒和SteamDB,帮助用户快速获取更多游戏相关信息和数据分析
// ==UserScript== // @name Steam增强器 // @namespace http://tampermonkey.net/ // @version 1.5.1 // @description 该脚本能够放大Steam平台的大部分界面元素,提升阅读和操作体验;在CSGO社区市场详情页显示Buff平台的价格对比并提供跳转链接,方便用户快速查看和购买;同时在游戏详情页添加快捷跳转按钮,连接到小黑盒和SteamDB,帮助用户快速获取更多游戏相关信息和数据分析 // @author Mr.Wan // @homepageURL https://github.com/wanbage8/SteamPlus // @icon  // @license GPL-3.0 License // @match *://store.steampowered.com/* // @match *://steamcommunity.com/* // @grant GM_addStyle // @grant GM_xmlhttpRequest // @connect steamcommunity.com // @connect buff.163.com // @connect api.steampowered.com // @connect steamcharts.com // @connect xiaoheihe.cn // ==/UserScript== (function () { GM_addStyle(` * { transition: var(--transition) var(--time)!important; border-radius: var(--borderR) !important; } :root{ --mainWidth:64vw; --mainMinWidth:940px; --transition:.3s; --borderR:5px; --time:ease-in-out; --csgoColor:#FFD700; } #Reviews_summary > div > div.leftcol {width:75%;} .rightcol.recent_reviews {width:calc(25% - 14px);} .review_box > div > .rightcol {width:calc(100% - 226px);} #highlight_strip_scroll, .forum_topic_tooltip {transition:0s !important;} .slider_ctn .handle, p {font-size: 15px;} .but { background-color: rgba(103, 193, 245, 0.2); box-shadow: none; margin-right: 2px; border-radius: 2px; cursor: pointer; margin-bottom: 3px; max-width: 200px; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; width: fit-content; height: 30px; display: flex; align-items: center; justify-content: center; } .wan-box { position: fixed; top: 25%; left: 25%; z-index: 999; width: 350px; padding: 10px; background-color: #ffffff8a; backdrop-filter: blur(5px); display: none; color: #000; cursor: move; -webkit-user-select: none; -moz-user-select: none; -ms-user-select: none; user-select: none; border: 1px solid #eee; } .switch-container { margin-top: 20px; } .flex { display: flex; align-items: center; justify-content: space-between; margin-bottom: 5px; } .switch { position: relative; display: inline-block; width: 53px; height: 25px; margin-left: 10px; } .switch input { opacity: 0; width: 0; height: 0; } .sliderBut { position: absolute; cursor: pointer; top: 0; left: 0; right: 0; bottom: 0; background-color: #ccc; transition: .4s; border-radius: 34px; } .sliderBut:before { position: absolute; content: ""; height: 20px; width: 20px; left: 4px; top: 50%; transform: translateY(-50%); background-color: #fff; transition: .4s; border-radius: 50%; } input:checked + .sliderBut { background-color: #2196F3; } input:focus + .sliderBut { box-shadow: 0 0 1px #2196F3; } input:checked + .sliderBut:before { transform: translate(26px, -50%); } .output { margin-top: 20px; font-size: 18px; } .wan-box-footer { display: flex; align-items: center; justify-content: space-around; margin-top: 10px; } .button { background-color: #2196F3; border: none; color: white; padding: 5px 10px; text-align: center; text-decoration: none; display: inline-block; font-size: 16px; margin: 4px 2px; cursor: pointer; border-radius: 5px; transition: background-color 0.3s ease; } .button:hover { background-color: #007BFF; } .button:active { background-color: #0056b3; transform: scale(0.98); } .title { font-size: 14px; font-weight: bold; } .radio-mar { margin-left: 10px; } [type="range"] { margin-left: 10px; } .community_home_header { max-width: initial; width: var(--mainWidth); } .community_home_tabs { max-width: initial; width: var(--mainWidth); } #AppHubContent { max-width: initial; width:var(--mainWidth); } #modalContent { width:var(--mainWidth)!important; } .workshopItemControlsCtn.fixed_in_scroll#ScrollingItemControls { width: var(--mainWidth); margin:0 auto; } .apphub_HomeHeader, div#store_header:not([aria-label="商店菜单"]) .content { width: var(--mainWidth); max-width: initial; } .Broadcast_Card.apphub_Card, .Broadcast_Card .apphub_CardContentPreviewImage { max-width:initial; max-height:initial; } ._2nl8HoZ_rxg3AGpYs0N_UD.Panel.Focusable, .workshop_home_content{ width: var(--mainWidth); max-width: initial; } .pagecontent #BG_bottom.maincontent { width: var(--mainWidth)!important; } #tabs_basebg #leftContents { width:80%; max-width:initial; } #rightContents, #rightContents.sidebar.right_column { width:calc(20% - 10px); max-width:initial; } .responsive_tab_baseline, #mainContents, #tabs_basebg, #highlight_player_area, .highlight_overflow, .highlight_ctn, #search_result_container, div#store_header .content, .slideshow_content, .review_page_content{ max-width: initial; } .view_inventory_page .inventory_ctn, .view_inventory_page .inventory_ctn .inventory_page, .gameLogoHolder_default img{ width:100% } .trade_item_box { background-color: initial; } #BG_top_workshop { width: var(--mainWidth); background-size:100%; background-position: top; } .home_leftcol.home_tab_col { width:80%; } .flex_cols > .home_leftcol { width: 618px; } .home_rightcol { width:19%; } #search_resultsRows a.search_result_row { display: flex; } #search_resultsRows a.search_result_row .responsive_search_name_combined { width: calc(85% - 125px); display: flex; align-items: center; justify-content: space-between; } .search_result_row .col.search_released { width: 106px; flex-shrink: 0; } .left_column, #leftContents{ width: 80%; } .right_column { width:calc(20% - 10px); } .profile_subpage_column .maincontent, body.migrated_profile_page .profile_subpage_column #BG_bottom.maincontent { background: rgb(18, 27, 37); } .profile_subpage_column .profile_small_header_bg { background-image:initial; } .profile_flag, .progress-bar{ border-radius: 0px !important; } .browse_content .recommendation .recommendation_link { width: 100%; } .wear .wear-pointer .wear-pointer-icon { margin-left: -6px; position: absolute; width: 0; height: 0; border-style: solid; border-width: 6px 6px 0 6px; border-color: #515151 transparent transparent transparent; } .wear-pointer { width: 180px; position: relative; padding-bottom: 4px; margin-top: 3px; } .progress { overflow: hidden; height: 5px; width: 180px; } .progress { height: 5px; overflow: hidden; background-color: #f5f5f5; border-radius: 4px; -webkit-box-shadow: inset 0 1px 2px rgba(0,0,0,.1); box-shadow: inset 0 1px 2px rgba(0,0,0,.1); box-sizing: border-box; } .wear-pointer-icon { margin-left: -6px; position: absolute; width: 0; height: 0; border-style: solid; border-width: 6px 6px 0 6px; border-color: #515151 transparent transparent transparent; } .progress-bar { float: left; width: 0; height: 100%; font-size: 12px; line-height: 20px; color: #fff; text-align: center; background-color: #337ab7; -webkit-transition: width .6s ease; -o-transition: width .6s ease; transition: width .6s ease; } .progress-bar-fn { background-color: green; } .progress-bar-success { background-color: #5cb85c; } .progress-bar-warning { background-color: #f0ad4e; } .progress-bar-danger { background-color: #d9534f; } .progress-bar-bs { background-color: #993A38; } .sticker { position: relative; } .sticker-2 { background: #474747; padding: 10px; position: absolute; top: -50%; transform: translateY(60%); left: 76%; opacity: 0; cursor: pointer; } .sticker-2::before { content: ''; border:10px solid transparent; border-right-color: #474747; position: absolute; top: 50%; transform: translateY(-50%); left: -20px; } .sticker:hover img { width: 75px; height: 75px; } .sticker:hover .sticker-2 { opacity: 1; } .BUFF-active { animation: borderColor 1s linear infinite; border: var(--csgoColor) 2px solid; } @keyframes borderColor { 0%{ border-color: var(--csgoColor); } 50%{ border-color: transparent; } 100%{ border-color: var(--csgoColor); } } #BUFF-up { width: 35px; height: 35px; border-radius: 50%; border: 1px solid var(--csgoColor); display: flex; align-items: center; justify-content: center; position: fixed; right: -50px; top: -50%; transform: translateY(-50%); opacity: 0; } #steam-date { position: absolute; transform: translateY(-100%); display: flex; align-items: center; user-select: none; } #menu{ position: absolute; height: 0; overflow-y: scroll; top: 100%; background-color: #ffffff8a; backdrop-filter: blur(4px); padding: 0; color: #343434; line-height: 25px; cursor: pointer; z-index: 999; } #menu div{ white-space: nowrap; } #menu div:hover{ color:#101010 } #menu-option{ border: #575757 1px solid; padding: 3px; cursor: pointer; background-color: #e5e5e5c7; } #menu-option:hover #menu{ height: 295px; padding: 5px; } `) /*======修改页面宽度======*/ /* * 规则集: * 可自定义添加 * 类名:{ * css属性:值 * } * */ let combinedRules = { "div.leftcol": { "width": "70%" }, "div.rightcol": { "width": "calc(30% - 14px)%" }, "img.game_header_image_full": { "width": "100%" }, ".queue_ctn": { "width": "var(--mainWidth)" }, ".game_area_play_stats": { "width": "var(--mainWidth)", "max-width": "initial" }, ".leftcol.game_description_column": { "width": "70%" }, ".rightcol.game_meta_data": { "width": "calc(30% - 14px)" }, "#review_create": { "width": "100%", "max-width": "initial" }, ".notice_box_content": { "width": "calc(100% - 29px)" }, "#game_recommendation": { "width": "calc(100% - 27px)", "max-width": "calc(100% - 27px)", "transition": "initial !important" }, ".review_controls": { "width": "calc(100% - 19px)", "max-width": "calc(100% - 19px)" }, ".game_language_options": { "width": "100%" }, "body.v6 .page_content": { "width": "var(--mainWidth)" }, ".game_page_background.game .responsive_store_nav_ctn_spacer #store_header .content": { "width": "var(--mainWidth)" }, ".apphub_HomeHeaderContent": { "max-width": "initial" }, "#responsive_page_template_content .apphub_HomeHeaderContent": { "width": "var(--mainWidth)", "max-width": "initial" }, ".glance_tags.popular_tags": { "display": "flex", "flex-wrap": "wrap", "height": "fit-content" }, ".similar_recent_apps_container": { "height": "fit-content", "flex-wrap": "wrap" }, "#gameHeaderImageCtn img": { "height": "auto", "width": "100%" }, ".rightcol.small.responsive_local_menu.autocollapse_enabled#additional_search_options": { "width": "calc(30% - 14px)", }, "search_result_container": { "max-width": "initial" }, ".page_content_ctn.friend_activity .page_content .rightcol": { "width": "calc(30% - 14px)", }, "#ig_bottom.nobg.mediaBody": { "width": "var(--mainWidth)", "max-width": "initial" }, "#responsive_page_template_content .breadcrumbs": { "width": "var(--mainWidth)", "max-width": "initial" }, "#ItemControls": { "width": "initial", "max-width": "initial" }, "#profileBlock.clearfix": { "width": "80%", "max-width": "initial" }, ".subSection.detailBox": { "background-position": "top", "background-size": "100%", }, ".responsive_local_menu#rightContents": { "width": "calc(20% - 10px)", }, ".responsive_local_menu#rightContents .sidebar": { "width": "100%", }, "#blotter_page": { "width": "var(--mainWidth)", }, "#blotter_content": { "width": "80%", }, "#friendactivity_right_column": { "width": "20%", }, ".profile_small_header_bg": { "width": "var(--mainWidth)", "max-width": "initial" }, ".profile_small_header_texture": { "max-width": "initial" }, ".maincontent": { "width": "var(--mainWidth)", }, "#active_inventory_page.view_inventory_page": { "width": "initial", }, ".view_inventory_page .inventory_page_left": { "width": "calc(100% - 360px)", }, ".view_inventory_page #inventories": { "width": "calc(100% - 6px)" }, ".apphub_HomeHeader": { "max-width": "initial" }, "html.responsive #ig_bottom": { "width": "var(--mainWidth)", "max-width": "initial" }, "#ig_bottom.smallheader": { "width": "var(--mainWidth)", "max-width": "initial" }, ".joinGroup": { "width": "initial", }, ".workshop_header": { "width": "var(--mainWidth)", "margin": "0 auto", }, ".apphub_ContentGuides": { "max-width": "initial", "width": "80%" }, "#game_highlights .rightcol": { "width": "30%", }, "#game_area_description": { "width": "initial", }, ".apphub_HomeHeaderContent .apphub_AppIcon": { "display": "block", "float": "left", "margin-right": "5px", }, "#AppHubContent .maincontent .rightcol.responsive_local_menu": { "width": "calc(30% - 18px)", }, "#AppHubContent .rightcol.responsive_local_menu": { "width": "calc(30% - 18px)", }, ".discussionSearchTextContainer": { "background-size": "100% 100%", "width": "100%", }, ".discussionSearchText.searchText": { "width": "calc(100% - 80px)", "left": "17px", }, ".discussionSearchTextSubmitImg": { "left": "90%", }, ".forum_op": { "max-width": "initial", "background-size": "100%" }, ".creator_announcement_browse_adjustment .browse_container": { "transform": "initial", "width": "100%", }, "body.v6.curator .page_content.browse_reviews": { "transform": "translateX(-160px)", }, ".saleEventBannerBig": { "width": "100%", }, ".saleEventBannerMobile": { "width": "100%", }, ".game_area_description": { "width": "100%", }, ".game_area_description img.bb_img": { "width": "100%", }, "#review_histogram_rollup_section": { "width": "70%", }, "#review_histogram_recent_section": { "width": "30%", } }; function applyStyles(rules) { for (let selector in rules) { const elements = document.querySelectorAll(selector); if (!elements || elements.length === 0) continue; elements.forEach(element => { let properties = rules[selector]; for (let property in properties) { let value = properties[property]; if (value === undefined || value === null) continue; element.style[property] = value; } }); } } applyStyles(combinedRules); //======自定义页面======// document.body.insertAdjacentHTML("beforeend", `<div class="wan-box" style="transition: 0s !important;"><h2 style="text-align: center;font-size: 26px;color: #000">Steam大屏Plus</h2><label for="range">页面宽度<input type="range" min="10" max="100" value="64" id="range"><span id="rangeNum">64</span><span id="unit">%视口宽度</span></label><div class="switch-container"><div class="flex"><span>是否启用全局圆角</span><label class="switch"><input type="checkbox" id="radius" checked><span class="sliderBut"></span></label></div><label for="radiusInp" title="设置圆角大小单位像素">圆角大小<input type="range" min="0" max="25" value="5" id="radiusInp"><span id="radiusNum">5</span>px</label></div><div class="switch-container"><div class="flex"><span>是否启用全局过渡</span><label class="switch"><input type="checkbox" id="transition" checked><span class="sliderBut"></span></label></div><label for="transitionInp" title="设置过渡时长单位秒(过渡时间过长可能导致某些元素响应慢)">过渡时长<input type="range" min="0" max="5" step="0.1" value="0.3" id="transitionInp"><span id="transitionNum">0.3</span>s<div>过渡曲线<label for="ease-in-out" class="radio-mar">快=>慢=>快<input type="radio" name="time" data-name="ease-in-out" id="ease-in-out" checked></label><label for="ease-out" class="radio-mar">慢=>快<input type="radio" name="time" data-name="ease-out" id="ease-out"></label><label for="linear" class="radio-mar">匀速<input type="radio" name="time" data-name="linear" id="linear"></label></div></label></div><div class="wan-box-footer"><button class="button" id="ok">确定</button><button class="button" id="no">取消</button><button class="button" id="reset" title="重置为Steam默认宽度">重置</button></div></div>`); let ranges = document.querySelectorAll("input[type='range']"); let range = document.querySelector("#range"); let radiusInp = document.querySelector("#radiusInp"); let radius = document.querySelector("#radius"); let transitionInp = document.querySelector("#transitionInp"); let transition = document.querySelector("#transition"); let ok = document.querySelector("#ok"); let no = document.querySelector("#no"); let wanBox = document.querySelector(".wan-box"); let reset = document.querySelector("#reset"); let data = JSON.parse(localStorage.getItem("state")); let unit = document.querySelector("#unit"); let timeOut = document.querySelectorAll("#transitionNum~div>label>input"); let steamURL = location.href let num = 0; let timeStatus = "ease-in-out" let state; let sw = { radius: 1, transition: 1 }; if (data) { state = data range.value = data.range; document.getElementById("rangeNum").innerText = data.range; radiusInp.value = data.radius; document.getElementById("radiusNum").innerText = data.radius; transitionInp.value = data.transition; document.getElementById("transitionNum").innerText = data.transition; document.documentElement.style.setProperty("--mainWidth", data.range + (data.range <= 100 ? "vw" : "px")); document.documentElement.style.setProperty("--transition", data.transition + "s"); document.documentElement.style.setProperty("--borderR", data.radius + "px"); document.documentElement.style.setProperty("--time", data.time); unit.innerText = state.range <= 100 ? "%视口宽度" : "px" } for (let i = 0; i < ranges.length; i++) { ranges[i].addEventListener("input", function () { this.nextElementSibling.innerHTML = this.value; }) } function toggleElement(ele) { if (ele.checked) { ele.parentElement.parentElement.nextElementSibling.style.display = "block"; sw[ele.id] = 1 } else { ele.parentElement.parentElement.nextElementSibling.style.display = "none"; sw[ele.id] = 0 } } radius.addEventListener("change", function () { toggleElement(this) }) transition.addEventListener("change", function () { toggleElement(this); }) ok.addEventListener("click", function () { state = { range: range.value, radius: sw.radius ? radiusInp.value : "0", transition: sw.transition ? transitionInp.value : "0", time: timeStatus, } localStorage.setItem("state", JSON.stringify(state)); wanBox.style.display = "none"; document.documentElement.style.setProperty("--mainWidth", state.range + "vw"); document.documentElement.style.setProperty("--transition", state.transition + "s"); document.documentElement.style.setProperty("--borderR", state.radius + "px"); document.documentElement.style.setProperty("--time", state.time); num++ }) no.addEventListener("click", function () { wanBox.style.display = "none"; num++ }) reset.addEventListener("click", function () { state.range = "940" localStorage.setItem("state", JSON.stringify(state)); wanBox.style.display = "none"; document.documentElement.style.setProperty("--mainWidth", state.range + "px"); num++ }) document.addEventListener("keyup", function (e) { if (e.altKey && e.keyCode === 65 && e.ctrlKey) { if (num % 2 === 0) { wanBox.style.display = "block" } else { wanBox.style.display = "none" } num++ } unit.innerText = state?.range <= 100 ? "%视口宽度" : "px" }) let move = false; let offset = [0, 0]; wanBox.addEventListener('mousedown', function (e) { if (e.target !== this && !e.target.closest('input[type="range"]')) { move = true; offset = [ wanBox.offsetLeft - e.clientX, wanBox.offsetTop - e.clientY ]; } }); document.addEventListener('mousemove', function (e) { if (move) { e.preventDefault(); wanBox.style.left = (e.clientX + offset[0]) + 'px'; wanBox.style.top = (e.clientY + offset[1]) + 'px'; } }); document.addEventListener('mouseup', function () { move = false; }); for (let i = 0; i < timeOut.length; i++) { timeOut[i].addEventListener("change", function () { timeStatus = this.getAttribute("data-name"); }) } let cont = localStorage.getItem("t"); if (!cont) { ShowAlertDialog('注意', '按下“Ctrl+Alt+A”键即可呼出Steam大屏Plus菜单', "明白!"); localStorage.setItem("t", "t") } //=============================游戏详情页&csgo市场=======================// let appId = steamURL.match(/app\/(\d+)/); let community = /https:\/\/steamcommunity.com\/market\/listings\/730/.test(steamURL) let headerStandard = document.querySelector(".apphub_HeaderStandardTop") let communityName = document.getElementById("largeiteminfo_item_name") let main = document.getElementById("BG_bottom") let tableMain = document.querySelector(".market_commodity_order_block") || document.getElementById("largeiteminfo_warning") let csgoName = "" let csgoId /** * 传入csgo磨损度返回对应的词语 * @param {Float} num -武器磨损度 * @return {String<崭新出厂|略有磨损|久经沙场|破损不堪|战痕累累|"">} * */ function csgoAbrasion(num) { if (0 <= num && num < 0.07) return "崭新出厂"; else if (0.07 <= num && num < 0.15) return "略有磨损"; else if (0.15 <= num && num < 0.37) return "久经沙场"; else if (0.37 <= num && num < 0.44) return "破损不堪"; else if (0.44 <= num && num <= 1) return "战痕累累"; else return ""; } /** * 消息提示 * @param {NodeList} dom -显示消息的容器 * @param {String<Selection>} node -消息内容 * @param {String<JSON>} [options] -额外配置 * */ function showMsg(dom, node, options) { let container = document.querySelectorAll(dom) for (let i = 0; i < container.length; i++) { if (document.querySelectorAll(dom)[i].dataset.msg) { container[i].innerHTML = document.querySelectorAll(dom)[i].dataset.msg continue } container[i].innerHTML = node } } /** * 数字单位转换为万 * @param {Number} number -要转换的数字 * @param {Number} [decimals=2] -要省略的位数 * */ function numberPro(number, decimals = 2) { if (typeof number !== 'number' || isNaN(number)) { throw new Error('提供的号码无效'); } const tenThousand = 10000; if (number >= tenThousand) { const formattedNumber = (number / tenThousand).toFixed(decimals); // 如果没有小数部分,则去掉小数点和后面的0 return parseFloat(formattedNumber) % 1 === 0 ? parseInt(formattedNumber, 10) + '万' : formattedNumber + '万'; } else { return number.toString(); } } // 游戏详情页 if (appId && headerStandard) { // 跳转启发来自 https://www.xiaoheihe.cn/app/bbs/link/144510651 headerStandard.insertAdjacentHTML("afterbegin", `<div class="apphub_OtherSiteInfo" style="margin-left: 10px" title="跳转到小黑盒"><a class="btnv6_blue_hoverfade btn_medium" href="https://www.xiaoheihe.cn/app/topic/game/pc/${appId[1]}"><img style="width: 29px;height: 29px;" src="https://imgheybox.max-c.com/oa/2024/11/27/3912834da32296bd985281f8944e75fc.ico" alt="小黑盒"></a></div>`) headerStandard.insertAdjacentHTML("afterbegin", `<div class="apphub_OtherSiteInfo" style="margin-left: 10px" title="跳转到SteamDB"><a class="btnv6_blue_hoverfade btn_medium" href="https://steamdb.info/app/${appId[1]}"><img style="width: 29px;height: 29px;" src="https://steamdb.info/static/logos/vector_prefers_schema.svg" alt="SteamDB"></a></div>`) let userPlay = document.querySelector(".glance_ctn_responsive_left") userPlay.insertAdjacentHTML("afterbegin", `<div class="dev_row" style="margin-top: 10px"><div class="subtitle column">在线人数:</div><div class="summary column" id="user-num" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">今日峰值:</div><div class="summary column user-num-max" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">历史峰值:</div><div class="summary column user-num-max" style="color: #8f98a0">查询中...</div></div><div class="dev_row"><div class="subtitle column">平均游戏时间:</div><div class="summary column user-num-max-hey" style="color: #8f98a0">查询中...</div></div>`) let userPlayDom = document.querySelectorAll(".user-num-max") // 当前游戏在线人数 GM_xmlhttpRequest({ method: "GET", url: `https://api.steampowered.com/ISteamUserStats/GetNumberOfCurrentPlayers/v1/?appid=${appId[1]}`, onload: function (res) { let data = JSON.parse(res.response) let msg = document.getElementById("user-num") if (data.response.result !== 1) { showMsg("#user-num", "查询结果异常") return; } msg.innerText = numberPro(data.response.player_count) || "查询结果异常" }, onerror: function (error) { throw new Error(error) showMsg("#user-num", "查询结果错误") } }); GM_xmlhttpRequest({ method: "GET", url: `https://steamcharts.com/app/${appId[1]}`, onload: function (res) { let userPlayArr try { let data = res.responseText userPlayArr = data.match(/(?<="num">)(\d+)/g) userPlayDom[0].textContent = numberPro(+userPlayArr[1]) userPlayDom[1].textContent = numberPro(+userPlayArr[2]) } catch (e) { showMsg(".user-num-max", "查询失败") throw new Error(e) } }, onerror: function (error) { throw new Error(error) showMsg(".user-num-max", "查询失败") } }); GM_xmlhttpRequest({ method: "GET", url: `https://www.xiaoheihe.cn/app/topic/game/pc/${appId[1]}`, headers: { "content-type": "application/json", "Referer": "https://www.xiaoheihe.cn/", "origin": "https://www.xiaoheihe.cn" }, onload: function (res) { let heyMsg = document.querySelector(".user-num-max-hey") let heyBoxHtml = document.createRange().createContextualFragment(res.responseText); try { let data = JSON.parse(heyBoxHtml.getElementById("__NUXT_DATA__").innerText); for (let i = 0; i < data.length; i++) { if (data[i] === "平均游戏时间") { heyMsg.textContent = `${data[i + 1] + '' !== "[object Object]" ? data[i + 1] + " 数据来源:小黑盒" : "暂无"}` } } } catch (e) { showMsg(".user-num-max-hey", "查询失败") throw new Error(e) } }, onerror: function (error) { throw new Error(error) } }); // steam市场增强 } else if (community && communityName) { // 延时加载 等待元素加载完成 setTimeout(function () { main.insertAdjacentHTML("beforeend", `<h2 class="market_section_title">网易BUFF</h2><span id="BUFF-total"></span><div id="searchResultsRows" style=""><div class="market_listing_table_header"><div class="market_listing_price_listings_block"><span class="market_listing_right_cell market_listing_action_buttons">跳转到BUFF</span><span class="market_listing_right_cell market_listing_their_price" style="text-align: center">价格</span><span class="market_listing_right_cell market_listing_their_price" style="width: 220px;text-align: center">磨损度</span></div><div><span class="market_listing_header_namespacer"></span>名称</div></div><div id="BUFF-body"></div><div id="content_loading" class="page_content_ctn dark" style="display: block;"><div class="home_page_content more_content" id="BUFF-loading"><div class="LoadingWrapper"><div class="LoadingThrobber"><div class="Bar Bar1"></div><div class="Bar Bar2"></div><div class="Bar Bar3"></div></div><div class="BUFF-msg LoadingText">正在加载更多内容…</div></div></div></div></div><div id="BUFF-up">⬆️</div>`) tableMain.insertAdjacentHTML("afterbegin", `<div class="market_commodity_orders_table_container"><table class="market_commodity_orders_table"><tbody id="BUFF-table"><tr><th align="right">编号</th><th align="right">Steam价格</th><th align="right">Buff价格</th><th align="right">利润</th><th align="right">折扣率</th></tr><tr class="BUFF-msg" id="BUFF-tablet-msg"><th colspan="5">查询中...</th></tr></tbody></table></div>`) let BUFFcontent = document.getElementById("BUFF-body") let BUFFtitle = document.getElementById("BUFF-title") let BUFFtable = document.getElementById("BUFF-table") let BUFFloading = document.getElementById("BUFF-loading") let BUFFtotal = document.getElementById("BUFF-total") let steamPrice = document.querySelector(".market_listing_price.market_listing_price_with_fee:not(.price-Buff)") let appearance = document.getElementById("largeiteminfo_item_descriptors").firstElementChild.textContent.match(/崭新出厂|略有磨损|久经沙场|破损不堪|战痕累累/) let pageNum = 1 let initNum = 1 let sliderObserver csgoName = communityName.innerText if (appearance) csgoName += appearance[0] BUFFtable.addEventListener("click", (e) => { if (!e.target.dataset.index) return; let index = e.target.dataset.index let list = document.querySelectorAll("#BUFF-body .market_listing_row.market_recent_listing_row")[index] list.classList.add("BUFF-active") list.scrollIntoView({behavior: 'smooth', block: 'center'}); let time = setTimeout(() => { list.classList.remove("BUFF-active") }, 5500) }) document.documentElement.style.setProperty("--csgoColor", communityName.style.color) communityName.insertAdjacentHTML("beforebegin", `<a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=${csgoName}" id="BUFF-URL"><img style="width: 40px;height: 40px;float: right;" title="跳转到BUFF" src="https://g.fp.ps.netease.com/market/file/59b156975e6027bce06e8f6ceTyFGdsj"></a>`) // 调用Buff查询接口查询商品ID GM_xmlhttpRequest({ method: "GET", url: `https://buff.163.com/api/market/goods?game=csgo&page_num=1&search=${csgoName}&use_suggestion=0&_=1738903063922`, headers: { "Referer": "https://buff.163.com/market/csgo", "Accept": "application/json, text/javascript, */*; q=0.01" }, onload: function (response) { let data = JSON.parse(response.response) console.log(data) if (data.code !== "OK") { showMsg(".BUFF-msg", `请求ID异常,异常信息:${data.error} 状态码:${data.code}`, data) return } else if (data.data.items.length === 0) { showMsg(".BUFF-msg", `未查询到该商品`) return; } // 创建观察器 sliderObserver = new IntersectionObserver((entries) => { let data = entries[0] if (!data.isIntersecting) return if (!csgoId) return getBUFFList() }) sliderObserver.observe(BUFFloading) if (data.data.items.length === 1 && data.data.items[0].id) { csgoId = data.data.items[0].id } else if (data.data.items.length > 1) { let dom = "" for (let i = 0; i < data.data.items.length; i++) { let index = data.data.items[i] if (communityName.innerText === data.data.items[i].short_name) { csgoId = data.data.items[i].id break; } else if (i === data.data.items.length - 1) { showMsg("#BUFF-tablet-msg", `<th colspan="5">价格异常</th>`) dom += `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index?.img_src || index.goods_info.icon_url}" onerror="this.src=document.querySelector('.market_listing_largeimage img').src" style="border-color: var(--csgoColor);" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a href="https://buff.163.com/goods/${index.id}"class="item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff ">¥ ${index.price || index.sell_reference_price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${index.name}</span><br><div class="market_listing_row_details economy_item_hoverable"><br><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;">${index.sell_num}件在售</div></div></div></div>` BUFFcontent.insertAdjacentHTML("beforeend", dom) sliderObserver.unobserve(BUFFloading) BUFFloading.remove() return; } dom += `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index?.img_src || index.goods_info.icon_url}" onerror="this.src=document.querySelector('.market_listing_largeimage img').src" style="border-color: var(--csgoColor);" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a href="https://buff.163.com/goods/${index.id}"class="item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff ">¥ ${index.price || index.sell_reference_price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${index.name}</span><br><div class="market_listing_row_details economy_item_hoverable"><br><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;">${index.sell_num}件在售</div></div></div></div>` } } steamPrice = steamPrice ? +steamPrice.innerText.replace(/[^\d.]/g, "") : +data.data?.goods_infos?.csgoId?.steam_price_cny || document.querySelectorAll(".market_commodity_orders_header_promote")[1]?.textContent.replace(/[^\d.]/g, "") || 0 // 拿到ID发送商品列表请求 getBUFFList() }, onerror(response) { throw new Error(response) showMsg(".BUFF-msg", `查询ID数据错误 请查看控制台`) } }); function getBUFFList() { GM_xmlhttpRequest({ method: "GET", url: `https://buff.163.com/api/market/goods/sell_order?game=csgo&goods_id=${csgoId}&page_num=${pageNum}&mode=&allow_tradable_cooldown=1`, headers: { "Referer": "https://buff.163.com/", "Accept": "application/json, text/javascript, */*; q=0.01" }, onload: function (response) { let data = JSON.parse(response.response) console.log(data) if (data.code !== "OK") { showMsg(".BUFF-msg", `请求列表异常,异常信息:${data.error} 状态码:${data.code}`, data) sliderObserver.unobserve(BUFFloading) return } else if (pageNum * 10 >= data.data.total_count) { showMsg(".LoadingText", `没有更多数据了`) sliderObserver.unobserve(BUFFloading) } else if (data.data.items.length === 0) { showMsg(".BUFF-msg", `未查询到该商品`) sliderObserver.unobserve(BUFFloading) return } document.getElementById("BUFF-tablet-msg").style.display = 'none' BUFFtotal.innerText = `总数:${data.data.total_count}` let sticker for (let i = 0; i < data.data.items.length; i++) { let index = data.data.items[i] BUFFcontent.insertAdjacentHTML("beforeend", `<div class="market_listing_row market_recent_listing_row"><div class="market_listing_item_img_container"><img src="${index.img_src}" style="border-color: var(--csgoColor); background: url('${data.data.src_url_background}');background-size: 100% 100%" class="market_listing_item_img economy_item_hoverable" alt=""></div><div class="market_listing_price_listings_block"><div class="market_listing_right_cell market_listing_action_buttons"><div class="market_listing_buy_button"><a data-appid="${index.asset_info?.appid}" data-assetid="${index.asset_info?.assetid}" data-sell_order_id="${index.id}" data-classid="${index.asset_info?.classid}" data-contextid="${index.asset_info?.contextid}" data-instanceid="${index.asset_info?.instanceid}" class="getBUFF item_market_action_button btn_green_white_innerfade btn_small"><span>跳转到BUFF</span></a></div></div><div class="market_listing_right_cell market_listing_their_price"><span class="market_table_value"><span class="market_listing_price market_listing_price_with_fee price-Buff">¥ ${index.price}</span><br></span></div><div class="market_listing_right_cell" style="width: 220px;"><div class="market_listing_row_action" style="margin: 0">磨损度:${index.asset_info?.paintwear || "暂无"}<div class="wear-pointer"><div class="wear-pointer-icon" style="left: ${+index.asset_info?.paintwear * 100 || "0"}%"></div></div><div class="progress" style="margin-bottom: 5px;"><div class="progress-bar progress-bar-fn" style="width: 7%;" title="崭新出厂"></div><div class="progress-bar progress-bar-success" style="width: 8%;" title="略有磨损"></div><div class="progress-bar progress-bar-warning" style="width: 23%;" title="久经沙场"></div><div class="progress-bar progress-bar-danger" style="width: 7%;" title="破损不堪"></div><div class="progress-bar progress-bar-bs" style="width: 55%;" title="战痕累累"></div></div></div></div></div><div class="market_listing_item_name_block"><span class="market_listing_item_name economy_item_hoverable" style="color: var(--csgoColor);">${data.data.goods_infos[csgoId].short_name}(${csgoAbrasion(+index.asset_info?.paintwear)})</span><div style="line-height: 35px;">${index.asset_info.info?.fraudwarnings ? "❗" + index.asset_info.info.fraudwarnings : ""}</div><div class="market_listing_row_details economy_item_hoverable"><div class="sticker_info sticker_infoBUFF" style="width:100px; margin:4px; padding:8px;"></div></div></div></div>`) BUFFtable.insertAdjacentHTML("beforeend", `<tr><td align="right" class=""><a href="javascript:" data-index="${initNum - 1}">${initNum}</a></td><td align="right">${steamPrice}</td><td align="right">${index.price}</td><td align="right">${(steamPrice - index.price).toFixed(2)}</td><td>${((1 - index.price / steamPrice) * 100).toFixed(2) + "%"}</td></tr>`) if (index.asset_info.info?.stickers.length !== 0) { sticker = document.querySelectorAll(".sticker_infoBUFF")[initNum - 1] for (let j = 0; j < index.asset_info.info.stickers.length; j++) { sticker.insertAdjacentHTML("beforeend", `<div class="sticker"><div class="sticker-2"><a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=印花 | ${index.asset_info.info.stickers[j].name}&tab=selling">${index.asset_info.info.stickers[j].name}</a><div>价格:${index.asset_info.info.stickers[j]?.sell_reference_price ? "¥" + index.asset_info.info.stickers[j].sell_reference_price : "暂无价格"}</div><div>磨损度:${index.asset_info.info.stickers[j]?.wear ? ((1 - +index.asset_info.info.stickers[j].wear) * 100).toFixed(2) + "%" : "完美无缺"}</div></div><img width="64" height="48" src="${index.asset_info.info.stickers[j].img_url}"></div>`) } } if (index.asset_info.info?.keychains.length !== 0) { for (let j = 0; j < index.asset_info.info.keychains.length; j++) { sticker.insertAdjacentHTML("beforeend", `<div class="sticker"><div class="sticker-2" style="transform: translateY(50%);left: 85%;"><a href="https://buff.163.com/market/csgo#game=csgo&page_num=1&search=挂件 | ${index.asset_info.info.keychains[j].name}&tab=selling">挂件 | ${index.asset_info.info.keychains[j].name}</a><div>挂件价格:${index.asset_info.info.keychains[j]?.sell_reference_price ? "¥" + index.asset_info.info.keychains[j].sell_reference_price : "暂无价格"}</div><div>挂件模板:${index.asset_info.info?.keychains[j].pattern || "暂无模板"}</div><div style="color: ${index.asset_info.info.keychains[j]?.pattern_color || "rgb(150, 150, 150)"}">挂件颜色:${index.asset_info.info.keychains[j]?.pattern_color || "暂无颜色"}</div></div><img width="64" height="48" src="${index.asset_info.info.keychains[j].img_url}"></div>`) } } initNum++ } let getBuff = document.querySelectorAll(".getBUFF") for (let i = 0; i < getBuff.length; i++) { getBuff[i].addEventListener("click", function () { let BuffData = {} BuffData.appid = this.dataset.appid BuffData.assetid = this.dataset.assetid BuffData.classid = this.dataset.classid BuffData.contextid = this.dataset.contextid BuffData.instanceid = this.dataset.instanceid BuffData.sell_order_id = this.dataset.sell_order_id let code = this.firstElementChild code.textContent = "正在跳转" location.href = `https://buff.163.com/goods/${csgoId}?appid=730&classid=${BuffData.classid}&instanceid=${BuffData.instanceid}&assetid=${BuffData.assetid}&contextid=${BuffData.contextid}&sell_order_id=${BuffData.sell_order_id}` }) } pageNum++ }, onerror(response) { throw new Error(response) showMsg(".BUFF-msg", `列表数据错误 请查看控制台`) sliderObserver.unobserve(BUFFloading) } }) } }, 500) } function upSteamDate() { let steamMenu = document.querySelector(".store_nav_bg") if (!steamMenu) return let timeStamp = new Date().getTime() let state = JSON.parse(localStorage.getItem("menu")) let menuData = [] const steamDate = { "0": { "name": "即时战略游戏节", "date": "1月21日 - 1月29日", "timeStampStart": 1737396000000, "timeStampEnd": 1738087200000 }, "1": { "name": "挂机游戏节", "date": "2月4日 - 2月11日", "timeStampStart": 1738605600000, "timeStampEnd": 1739210400000 }, "2": { "name": "沙发合作游戏节", "date": "2月11日 - 2月18日", "timeStampStart": 1739210400000, "timeStampEnd": 1739815200000 }, "3": { "name": "Steam新品节-2025年2月版", "date": "2月25日 - 3月4日", "timeStampStart": 1740420000000, "timeStampEnd": 1741024800000 }, "4": { "name": "视觉小说游戏节", "date": "3月4日 - 3月11日", "timeStampStart": 1741024800000, "timeStampEnd": 1741629600000 }, "5": { "name": "2025年Steam春季特卖", "date": "3月14日 - 3月21日", "timeStampStart": 1741888800000, "timeStampEnd": 1742493600000 }, "6": { "name": "城市营造及殖民模拟游戏节", "date": "3月25日 - 4月1日", "timeStampStart": 1742839200000, "timeStampEnd": 1743444000000 }, "7": { "name": "推箱子游戏节", "date": "4月22日 - 4月29日", "timeStampStart": 1745258400000, "timeStampEnd": 1745863200000 }, "8": { "name": "战争游戏节", "date": "4月29日 - 5月6日", "timeStampStart": 1745863200000, "timeStampEnd": 1746468000000 }, "9": { "name": "生物收集游戏节", "date": "5月13日 - 5月20日", "timeStampStart": 1747072800000, "timeStampEnd": 1747677600000 }, "10": { "name": "僵尸大战吸血鬼游戏节", "date": "5月27日 - 6月3日", "timeStampStart": 1748282400000, "timeStampEnd": 1748887200000 }, "11": { "name": "Steam新品节-2025年6月版", "date": "6月10日 - 6月17日", "timeStampStart": 1749492000000, "timeStampEnd": 1750096800000 }, "12": { "name": "钓鱼游戏节", "date": "6月17日 - 6月24日", "timeStampStart": 1750096800000, "timeStampEnd": 1750701600000 }, "13": { "name": "2025年Steam夏日特卖", "date": "6月27日 - 7月11日", "timeStampStart": 1750960800000, "timeStampEnd": 1752170400000 }, "14": { "name": "自动化游戏节", "date": "7月15日 - 7月22日", "timeStampStart": 1752516000000, "timeStampEnd": 1753120800000 }, "15": { "name": "竞速游戏节", "date": "7月29日 - 8月5日", "timeStampStart": 1753725600000, "timeStampEnd": 1754330400000 }, "16": { "name": "4X 游戏节", "date": "8月12日 - 8月19日", "timeStampStart": 1754935200000, "timeStampEnd": 1755540000000 }, "17": { "name": "第三人称射击游戏节", "date": "8月26日 - 9月2日", "timeStampStart": 1756144800000, "timeStampEnd": 1756749600000 }, "18": { "name": "政治模拟游戏节", "date": "9月9日 - 9月16日", "timeStampStart": 1757354400000, "timeStampEnd": 1757959200000 }, "19": { "name": "2025年Steam秋季特卖", "date": "9月30日 - 10月7日", "timeStampStart": 1759168800000, "timeStampEnd": 1759773600000 }, "20": { "name": "Steam 新品节 - 2025 年 10 月版", "date": "10月14日 - 10月21日", "timeStampStart": 1760378400000, "timeStampEnd": 1760983200000 }, "21": { "name": "Steam尖叫游戏节4", "date": "10月28日 - 11月4日", "timeStampStart": 1761588000000, "timeStampEnd": 1762192800000 }, "22": { "name": "动物游戏节", "date": "11月11日 - 11月18日", "timeStampStart": 1762797600000, "timeStampEnd": 1763402400000 }, "23": { "name": "体育游戏节", "date": "12月9日 - 12月16日", "timeStampStart": 1765216800000, "timeStampEnd": 1765821600000 }, "24": { "name": "2025 年 Steam 冬季特卖", "date": "12月19日 - 2026年1月6日", "timeStampStart": 1766080800000, "timeStampEnd": 1767636000000 } } steamMenu.insertAdjacentHTML("afterbegin", `<div id="steam-date"><span id="menu-option"><span id="menu-msg" style="color: rgb(101 101 101);" data-index="5">2025年Steam春季特卖✨</span><div id="menu"></div></span><span id="steam-date-time" style="margin: 0 5px"></span><span id="steam-date-msg" style="flex-shrink: 0"></span></div>`) let menu = document.getElementById("menu") let steamOption = document.getElementById("steam-option") let menuMsg = document.getElementById("menu-msg") let steamDateTime = document.getElementById("steam-date-time") let steamDateMsg = document.getElementById("steam-date-msg") let intervalId = null for (let i = 0; i < Object.keys(steamDate).length; i++) { if (steamDate[i].timeStampStart <= timeStamp) { if (steamDate[i].timeStampEnd >= timeStamp) { menu.insertAdjacentHTML("beforeend", `<div data-value="${steamDate[i].name}" data-index="${i}">${steamDate[i].name}-正在进行</div>`) menuMsg.innerText = steamDate[i].name menuMsg.dataset.index = i } else menu.insertAdjacentHTML("beforeend", `<div data-value="${steamDate[i].name}" style="text-decoration: line-through" data-index="${i}">${steamDate[i].name}-已结束</div>`) } else menu.insertAdjacentHTML("beforeend", `<div data-value="${steamDate[i].name}" data-index="${i}">${steamDate[i].name}</div>`) } if (state) { menuMsg.innerText = state[0] menuMsg.dataset.index = state[1] } upMenuDate(menuMsg.dataset.index) menu.addEventListener("click", (e) => { let ele = e.target if (!ele.dataset.value) return menuData = [ele.dataset.value, ele.dataset.index] menuMsg.innerText = menuData[0] menuMsg.dataset.index = menuData[1] menuMsg.style.textDecoration = ele.style.textDecoration ? "line-through" : "" localStorage.setItem("menu", JSON.stringify(menuData)) upMenuDate(menuData[1]) }) function upMenuDate(menuDataIndex) { let steamDateIndex = steamDate[menuDataIndex]; steamDateMsg.innerText = steamDateIndex.date if (intervalId !== null) clearInterval(intervalId); intervalId = setInterval(() => { const time = getDate(); let timeDifference = (steamDateIndex.timeStampStart - time.timeStatus) / 1000 if (timeDifference >= 0) { steamDateTime.innerText = `还剩${parseInt(timeDifference / 86400)}天${parseInt((timeDifference % (24 * 60 * 60)) / (60 * 60))}小时${parseInt(timeDifference % 3600 / 60)}分${parseInt(timeDifference % 60)}秒` } else { if (steamDateIndex.timeStampEnd >= time.timeStatus) { let timeDifferenceEnd = (steamDateIndex.timeStampEnd - time.timeStatus) / 1000 steamDateTime.innerText = `还剩${parseInt(timeDifferenceEnd / 86400)}天${parseInt((timeDifferenceEnd % (24 * 60 * 60)) / (60 * 60))}小时${parseInt(timeDifferenceEnd % 3600 / 60)}分${parseInt(timeDifferenceEnd % 60)}秒 结束` } else { steamDateTime.innerText = `已结束` } } }, 1000); } } upSteamDate() /** * 获取现在的时间 * @return {Object} - 时间对象 * */ function getDate() { let date = new Date() return { year: date.getFullYear(), month: date.getMonth() + 1, date: date.getDate(), sec: date.getSeconds(), timeStatus: date.getTime() } } })();